diff options
Diffstat (limited to 'mac/.config/sketchybar.mon')
116 files changed, 7336 insertions, 0 deletions
diff --git a/mac/.config/sketchybar.mon/colors.sh b/mac/.config/sketchybar.mon/colors.sh new file mode 100755 index 0000000..cdbd908 --- /dev/null +++ b/mac/.config/sketchybar.mon/colors.sh @@ -0,0 +1,104 @@ +#!/bin/bash + +### Sonokai +# export BLACK=0xff181819 #181819 +# export WHITE=0xffe2e2e3 #e2e2e3 +# export RED=0xfffc5d7c #fc5d7c +# export GREEN=0xff9ed072 #9ed072 +# export BLUE=0xff76cce0 #76cce0 +# export YELLOW=0xffe7c664 #e7c664 +# export ORANGE=0xfff39660 #f39660 +# export MAGENTA=0xffb39df3 #b39df3 +# export GREY=0xff7f8490 #7f8490 +# export BG0=0xff2c2e34 #2c2e34 +# export BG1=0xff363944 #363944 +# export BG2=0xff414550 #414550 +# export TRANSPARENT=0x00000000 #000000 + +### Catppuccin +export ROSEWATER=0xfff4dbd6 #f4dbd6 +export FLAMINGO=0xfff0c6c6 #f0c6c6 +export PINK=0XFff5bde6 #f5bde6 +export MAUVE=0Xffc6a0f6 #c6a0f6 +export RED=0XFFed8796 #ed8796 +export MAROON=0xffee99a0 #ee99a0 +export PEACH=0Xfff5a97f #f5a97f +export YELLOW=0xffeed49f #eed49f +export GREEN=0Xffa6da95 #a6da95 +export TEAL=0XFf8bd5ca #8bd5ca +export SKY=0XFF91d7e3 #91d7e3 +export SAPPHIRE=0xff7dc4e4 #7dc4e4 +export BLUE=0XFf8aadf4 #8aadf4 +export LAVENDER=0xffb7bdf8 #b7bdf8 +export TEXT=0xffcad3f5 #cad3f5 +export SUBTEXT1=0xffb8c0e0 #b8c0e0 +export SUBTEXT0=0xffa5adcb #a5adcb +export OVERLAY2=0xff939ab7 #939ab7 +export OVERLAY1=0xff8087a2 #8087a2 +export OVERLAY0=0xff6e738d #6e738d +export SURFACE2=0xff5b6078 #5b6078 +export SURFACE1=0xff494d64 #494d64 +export SURFACE0=0xff363a4f #363a4f +export BASE=0XFf24273a #24273a +export MANTLE=0xff1e2030 #1e2030 +export CRUST=0Xff181926 #181926 + +# Others +export MAGENTA=0xffc6a0f6 #c6a0f6 +export ORANGE=0xfff5a97f #f5a97f +export CYAN=0xff89DDFF #89DDFF +export OSBLUE=0xff0259D1 #0259D1 + +# Base Colors +export BASE=0xff24273a #24273a +export BASE_BLACK="181926" #181926 +export BASE_WHITE="eeeeee" #eeeeee +export WHITE=0xffcad3f5 #cad3f5 +export LIGHT_GREY=0xffa6accd #a6accd +export GREY=0xff939ab7 #939ab7 +export GREY_50=0x80676e95 #676e95 +export DARK_GREY=0xff292d3e #292d3e +export BLACK=0xff181926 #181926 +export BG0=0xff1e1e2e #1e1e2e +export BG1=0x603c3e4f #3c3e4f +export BG2=0x60494d64 #494d64 +export TRANSPARENT=0x00000000 #000000 + +O100=0xff # 100% +O75=0xbf # 75% +O50=0x80 # 50% +O25=0x40 # 25% +O10=0x1a # 10% + +export BLACK_75="$O75""$BASE_BLACK" +export BLACK_50="$O50""$BASE_BLACK" +export BLACK_25="$O25""$BASE_BLACK" +export WHITE_75="$O75""$BASE_WHITE" +export WHITE_50="$O50""$BASE_WHITE" +export WHITE_25="$O25""$BASE_WHITE" +export WHITE_10="$O10""$BASE_WHITE" + +# Text Colors +export TEXT=0xffcad3f5 #cad3f5 +export SUBTEXT0=0xffb8c0e0 #b8c0e0 +export SUBTEXT1=0xffa5adcb #a5adcb +export SURFACE0=0xff363a4f #363a4f +export SURFACE1=0xff494d64 #494d64 +export SURFACE2=0xff5b6078 #5b6078 +export OVERLAY0=0xff6e738d #6e738d +export OVERLAY1=0xff8087a2 #8087a2 +export OVERLAY2=0xff939ab7 #939ab7 + +# General Bar Colors +export BAR_COLOR=$BG0 +export BAR_BORDER_COLOR=$BG2 +export BACKGROUND_1=$BG1 +export BACKGROUND_2=$BG2 +export CONTRAST=0xff34324a #34324a +export HIGHLIGHT=$TEAL +export ICON_COLOR=$WHITE # Color of all icons +export ICON_COLOR_INACTIVE=$GREY +export LABEL_COLOR=$WHITE # Color of all labels +export POPUP_BACKGROUND_COLOR=$BAR_COLOR +export POPUP_BORDER_COLOR=$WHITE +export SHADOW_COLOR=$BLACK diff --git a/mac/.config/sketchybar.mon/globalstyles.sh b/mac/.config/sketchybar.mon/globalstyles.sh new file mode 100755 index 0000000..9f9eefb --- /dev/null +++ b/mac/.config/sketchybar.mon/globalstyles.sh @@ -0,0 +1,132 @@ +#!/bin/bash + +# Load defined icons +source "$CONFIG_DIR/icons.sh" + +# Load defined colors +source "$CONFIG_DIR/colors.sh" + +PADDINGS=8 +FONT="Hack Nerd Font" + +# Bar Appearance +bar=( + color=$BAR_COLOR + sticky=on + height=28 + padding_left=$PADDINGS + padding_right=$PADDINGS + corner_radius=0 + blur_radius=0 + border_width=2 + border_color=$TRANSPARENT + background_color=$BAR_COLOR + shadow=off + position=top + padding_right=10 + padding_left=10 + # y_offset=-2 + margin=-5 + sticky=on + topmost=off # on/off/window +) + +# Setting up default values +defaults=( + updates=when_shown + icon.font="$FONT:Bold:10.0" + icon.color=$ICON_COLOR + icon.padding_left=$PADDINGS + icon.padding_right=$PADDINGS + label.font="$FONT:Semibold:13" + label.color=$LABEL_COLOR + label.padding_left=$PADDINGS + label.padding_right=$PADDINGS + padding_right=$PADDINGS + padding_left=$PADDINGS + background.color=$BAR_COLOR + background.height=24 + background.corner_radius=3 + background.border_width=1 + popup.background.border_width=2 + popup.background.corner_radius=9 + popup.background.border_color=$POPUP_BORDER_COLOR + popup.background.color=$POPUP_BACKGROUND_COLOR + popup.blur_radius=20 + popup.background.shadow.drawing=on + scroll_texts=on +) + +bracket_defaults=( + background.height=24 + background.color=$BAR_COLOR + blur_radius=32 + background.corner_radius=$PADDINGS +) + +icon_defaults=( + label.drawing=off +) + +# Item Defaults +item_defaults=( + background.color=$TRANSPARENT + background.padding_left=$(($PADDINGS / 2)) + background.padding_right=$(($PADDINGS / 2)) + icon.padding_left=2 + icon.padding_right=$(($PADDINGS / 2)) + icon.background.corner_radius=4 + icon.background.height=24 + icon.font="$FONT:Regular:12" + icon.color=$ICON_COLOR + icon.highlight_color=$HIGHLIGHT + label.font="$FONT:Regular:12" + label.color=$LABEL_COLOR + label.highlight_color=$HIGHLIGHT + label.padding_left=$(($PADDINGS / 2)) + updates=when_shown + scroll_texts=on +) + +menu_defaults=( + popup.background.border_color=$POPUP_BORDER_COLOR + popup.background.color=$POPUP_BACKGROUND_COLOR + popup.background.shadow.drawing=on + popup.blur_radius=32 + popup.background.corner_radius=$PADDINGS + popup.background.shadow.drawing=on + popup.background.border_width=1 +) + +menu_item_defaults=( + label.font="$FONT:Regular:13" + padding_left=$PADDINGS + padding_right=$PADDINGS + icon.padding_left=0 + icon.color=$HIGHLIGHT + background.color=$TRANSPARENT +) + +notification_defaults=( + drawing=off + update_freq=120 + updates=on + background.color=$WHITE_25 + background.height=24 + background.corner_radius=16 + icon.font.size=10 + icon.padding_left=$PADDINGS + icon.padding_right=0 + icon.color=$BLACK_75 + label.color=$BLACK_75 + label.padding_right=$PADDINGS + label.font.size=11 + label.font.style=Bold +) + +separator=( + background.height=1 + width=200 + background.color=$WHITE_25 + background.y_offset=-16 +) diff --git a/mac/.config/sketchybar.mon/helper/cpu.h b/mac/.config/sketchybar.mon/helper/cpu.h new file mode 100644 index 0000000..c350ae3 --- /dev/null +++ b/mac/.config/sketchybar.mon/helper/cpu.h @@ -0,0 +1,122 @@ +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> +#include <mach/mach.h> +#include <stdbool.h> +#include <time.h> + +#define MAX_TOPPROC_LEN 28 + +static const char TOPPROC[] = { "/bin/ps -Aceo pid,pcpu,comm -r" }; +static const char FILTER_PATTERN[] = { "com.apple." }; + +struct cpu { + host_t host; + mach_msg_type_number_t count; + host_cpu_load_info_data_t load; + host_cpu_load_info_data_t prev_load; + bool has_prev_load; + + char command[256]; +}; + +static inline void cpu_init(struct cpu* cpu) { + cpu->host = mach_host_self(); + cpu->count = HOST_CPU_LOAD_INFO_COUNT; + cpu->has_prev_load = false; + snprintf(cpu->command, 100, ""); +} + +static inline void cpu_update(struct cpu* cpu) { + kern_return_t error = host_statistics(cpu->host, + HOST_CPU_LOAD_INFO, + (host_info_t)&cpu->load, + &cpu->count ); + + if (error != KERN_SUCCESS) { + printf("Error: Could not read cpu host statistics.\n"); + return; + } + + if (cpu->has_prev_load) { + uint32_t delta_user = cpu->load.cpu_ticks[CPU_STATE_USER] + - cpu->prev_load.cpu_ticks[CPU_STATE_USER]; + + uint32_t delta_system = cpu->load.cpu_ticks[CPU_STATE_SYSTEM] + - cpu->prev_load.cpu_ticks[CPU_STATE_SYSTEM]; + + uint32_t delta_idle = cpu->load.cpu_ticks[CPU_STATE_IDLE] + - cpu->prev_load.cpu_ticks[CPU_STATE_IDLE]; + + double user_perc = (double)delta_user / (double)(delta_system + + delta_user + + delta_idle); + + double sys_perc = (double)delta_system / (double)(delta_system + + delta_user + + delta_idle); + + double total_perc = user_perc + sys_perc; + + FILE* file; + char line[1024]; + + file = popen(TOPPROC, "r"); + if (!file) { + printf("Error: TOPPROC command errored out...\n" ); + return; + } + + fgets(line, sizeof(line), file); + fgets(line, sizeof(line), file); + + char* start = strstr(line, FILTER_PATTERN); + char topproc[MAX_TOPPROC_LEN + 4]; + uint32_t caret = 0; + for (int i = 0; i < sizeof(line); i++) { + if (start && i == start - line) { + i+=9; + continue; + } + + if (caret >= MAX_TOPPROC_LEN && caret <= MAX_TOPPROC_LEN + 2) { + topproc[caret++] = '.'; + continue; + } + if (caret > MAX_TOPPROC_LEN + 2) break; + topproc[caret++] = line[i]; + if (line[i] == '\0') break; + } + + topproc[MAX_TOPPROC_LEN + 3] = '\0'; + + pclose(file); + + char color[16]; + if (total_perc >= .7) { + snprintf(color, 16, "%s", getenv("RED")); + } else if (total_perc >= .3) { + snprintf(color, 16, "%s", getenv("ORANGE")); + } else if (total_perc >= .1) { + snprintf(color, 16, "%s", getenv("YELLOW")); + } else { + snprintf(color, 16, "%s", getenv("LABEL_COLOR")); + } + + snprintf(cpu->command, 256, "--push cpu.sys %.2f " + "--push cpu.user %.2f " + "--set cpu.top label='%s' " + "--set cpu.percent label=%.0f%% label.color=%s ", + sys_perc, + user_perc, + topproc, + total_perc*100., + color ); + } + else { + snprintf(cpu->command, 256, ""); + } + + cpu->prev_load = cpu->load; + cpu->has_prev_load = true; +} diff --git a/mac/.config/sketchybar.mon/helper/helper b/mac/.config/sketchybar.mon/helper/helper Binary files differnew file mode 100755 index 0000000..050cca7 --- /dev/null +++ b/mac/.config/sketchybar.mon/helper/helper diff --git a/mac/.config/sketchybar.mon/helper/helper.c b/mac/.config/sketchybar.mon/helper/helper.c new file mode 100644 index 0000000..71c3038 --- /dev/null +++ b/mac/.config/sketchybar.mon/helper/helper.c @@ -0,0 +1,31 @@ +#include "cpu.h" +#include "sketchybar.h" + +struct cpu g_cpu; + +void handler(env env) { + // Environment variables passed from sketchybar can be accessed as seen below + char* name = env_get_value_for_key(env, "NAME"); + char* sender = env_get_value_for_key(env, "SENDER"); + char* info = env_get_value_for_key(env, "INFO"); + char* selected = env_get_value_for_key(env, "SELECTED"); + + if ((strcmp(name, "cpu.percent") == 0)) { + // CPU graph updates + cpu_update(&g_cpu); + + if (strlen(g_cpu.command) > 0) sketchybar(g_cpu.command); + } +} + +int main (int argc, char** argv) { + cpu_init(&g_cpu); + + if (argc < 2) { + printf("Usage: helper \"<bootstrap name>\"\n"); + exit(1); + } + + event_server_begin(handler, argv[1]); + return 0; +} diff --git a/mac/.config/sketchybar.mon/helper/makefile b/mac/.config/sketchybar.mon/helper/makefile new file mode 100644 index 0000000..ac8721a --- /dev/null +++ b/mac/.config/sketchybar.mon/helper/makefile @@ -0,0 +1,3 @@ + +helper: helper.c cpu.h sketchybar.h + clang -std=c99 -O3 helper.c -o helper diff --git a/mac/.config/sketchybar.mon/helper/sketchybar.h b/mac/.config/sketchybar.mon/helper/sketchybar.h new file mode 100644 index 0000000..2ab4c39 --- /dev/null +++ b/mac/.config/sketchybar.mon/helper/sketchybar.h @@ -0,0 +1,209 @@ +#pragma once + +#include <mach/mach.h> +#include <mach/mach_port.h> +#include <mach/message.h> +#include <bootstrap.h> +#include <stdlib.h> +#include <pthread.h> +#include <stdio.h> + +typedef char* env; + +#define MACH_HANDLER(name) void name(env env) +typedef MACH_HANDLER(mach_handler); + +struct mach_message { + mach_msg_header_t header; + mach_msg_size_t msgh_descriptor_count; + mach_msg_ool_descriptor_t descriptor; +}; + +struct mach_buffer { + struct mach_message message; + mach_msg_trailer_t trailer; +}; + +struct mach_server { + bool is_running; + mach_port_name_t task; + mach_port_t port; + mach_port_t bs_port; + + pthread_t thread; + mach_handler* handler; +}; + +static struct mach_server g_mach_server; +static mach_port_t g_mach_port = 0; + +static inline char* env_get_value_for_key(env env, char* key) { + uint32_t caret = 0; + for(;;) { + if (!env[caret]) break; + if (strcmp(&env[caret], key) == 0) + return &env[caret + strlen(&env[caret]) + 1]; + + caret += strlen(&env[caret]) + + strlen(&env[caret + strlen(&env[caret]) + 1]) + + 2; + } + return (char*)""; +} + +static inline mach_port_t mach_get_bs_port() { + mach_port_name_t task = mach_task_self(); + + mach_port_t bs_port; + if (task_get_special_port(task, + TASK_BOOTSTRAP_PORT, + &bs_port ) != KERN_SUCCESS) { + return 0; + } + + mach_port_t port; + if (bootstrap_look_up(bs_port, + "git.felix.sketchybar", + &port ) != KERN_SUCCESS) { + return 0; + } + + return port; +} + +static inline void mach_receive_message(mach_port_t port, struct mach_buffer* buffer, bool timeout) { + *buffer = (struct mach_buffer) { 0 }; + mach_msg_return_t msg_return; + if (timeout) + msg_return = mach_msg(&buffer->message.header, + MACH_RCV_MSG | MACH_RCV_TIMEOUT, + 0, + sizeof(struct mach_buffer), + port, + 100, + MACH_PORT_NULL ); + else + msg_return = mach_msg(&buffer->message.header, + MACH_RCV_MSG, + 0, + sizeof(struct mach_buffer), + port, + MACH_MSG_TIMEOUT_NONE, + MACH_PORT_NULL ); + + if (msg_return != MACH_MSG_SUCCESS) { + buffer->message.descriptor.address = NULL; + } +} + +static inline char* mach_send_message(mach_port_t port, char* message, uint32_t len) { + if (!message || !port) { + return NULL; + } + + struct mach_message msg = { 0 }; + msg.header.msgh_remote_port = port; + msg.header.msgh_local_port = 0; + msg.header.msgh_id = 0; + msg.header.msgh_bits = MACH_MSGH_BITS_SET(MACH_MSG_TYPE_COPY_SEND, + MACH_MSG_TYPE_MAKE_SEND, + 0, + MACH_MSGH_BITS_COMPLEX ); + + msg.header.msgh_size = sizeof(struct mach_message); + msg.msgh_descriptor_count = 1; + msg.descriptor.address = message; + msg.descriptor.size = len * sizeof(char); + msg.descriptor.copy = MACH_MSG_VIRTUAL_COPY; + msg.descriptor.deallocate = false; + msg.descriptor.type = MACH_MSG_OOL_DESCRIPTOR; + + mach_msg(&msg.header, + MACH_SEND_MSG, + sizeof(struct mach_message), + 0, + MACH_PORT_NULL, + MACH_MSG_TIMEOUT_NONE, + MACH_PORT_NULL ); + + return NULL; +} + +#pragma clang diagnostic push +#pragma clang diagnostic ignored "-Wdeprecated-declarations" +static inline bool mach_server_begin(struct mach_server* mach_server, mach_handler handler, char* bootstrap_name) { + mach_server->task = mach_task_self(); + + if (mach_port_allocate(mach_server->task, + MACH_PORT_RIGHT_RECEIVE, + &mach_server->port ) != KERN_SUCCESS) { + return false; + } + + if (mach_port_insert_right(mach_server->task, + mach_server->port, + mach_server->port, + MACH_MSG_TYPE_MAKE_SEND) != KERN_SUCCESS) { + return false; + } + + if (task_get_special_port(mach_server->task, + TASK_BOOTSTRAP_PORT, + &mach_server->bs_port) != KERN_SUCCESS) { + return false; + } + + if (bootstrap_register(mach_server->bs_port, + bootstrap_name, + mach_server->port ) != KERN_SUCCESS) { + return false; + } + + mach_server->handler = handler; + mach_server->is_running = true; + struct mach_buffer buffer; + while (mach_server->is_running) { + mach_receive_message(mach_server->port, &buffer, false); + mach_server->handler((env)buffer.message.descriptor.address); + mach_msg_destroy(&buffer.message.header); + } + + return true; +} +#pragma clang diagnostic pop + +static inline char* sketchybar(char* message) { + uint32_t message_length = strlen(message) + 1; + char formatted_message[message_length + 1]; + + char quote = '\0'; + uint32_t caret = 0; + for (int i = 0; i < message_length; ++i) { + if (message[i] == '"' || message[i] == '\'') { + if (quote == message[i]) quote = '\0'; + else quote = message[i]; + continue; + } + formatted_message[caret] = message[i]; + if (message[i] == ' ' && !quote) formatted_message[caret] = '\0'; + caret++; + } + + if (caret > 0 && formatted_message[caret] == '\0' + && formatted_message[caret - 1] == '\0') { + caret--; + } + + formatted_message[caret] = '\0'; + if (!g_mach_port) g_mach_port = mach_get_bs_port(); + char* response = mach_send_message(g_mach_port, + formatted_message, + caret + 1 ); + + if (response) return response; + else return (char*)""; +} + +static inline void event_server_begin(mach_handler event_handler, char* bootstrap_name) { + mach_server_begin(&g_mach_server, event_handler, bootstrap_name); +} diff --git a/mac/.config/sketchybar.mon/icons.sh b/mac/.config/sketchybar.mon/icons.sh new file mode 100755 index 0000000..2321507 --- /dev/null +++ b/mac/.config/sketchybar.mon/icons.sh @@ -0,0 +1,70 @@ +#!/bin/bash + +# General Icons +LOADING= +APPLE= +PREFERENCES= +ACTIVITY= +LOCK= +BELL= +BELL_DOT= + +# Git Icons +GIT_ISSUE= +GIT_DISCUSSION= +GIT_PULL_REQUEST= +GIT_COMMIT= +GIT_INDICATOR= + +# Music +MUSIC= + +# Spotify Icons +SPOTIFY_BACK= +SPOTIFY_PLAY_PAUSE= +SPOTIFY_NEXT= +SPOTIFY_SHUFFLE= +SPOTIFY_REPEAT= + +# Yabai Icons +YABAI_STACK= +YABAI_FULLSCREEN_ZOOM= +YABAI_PARENT_ZOOM= +YABAI_FLOAT= +YABAI_GRID= +YABAI_SPLIT_VERTICAL= +YABAI_SPLIT_HORIZONTAL= + +# Battery Icons +BATTERY= +BATTERY_100= +BATTERY_75= +BATTERY_50= +BATTERY_25= +BATTERY_0= +BATTERY_CHARGING= + +CPU= +DISK= +MEMORY= +NETWORK= +NETWORK_UP= +NETWORK_DOWN= + +# Volume Icons +VOLUME_100= +VOLUME_66= +VOLUME_33= +VOLUME_10= +VOLUME_0= + +# WiFi +WIFI_CONNECTED= +WIFI_DISCONNECTED= + +# svim +MODE_NORMAL= +MODE_INSERT= +MODE_VISUAL= +MODE_CMD= +MODE_PENDING= diff --git a/mac/.config/sketchybar.mon/items/apple.sh b/mac/.config/sketchybar.mon/items/apple.sh new file mode 100755 index 0000000..5f4e9dc --- /dev/null +++ b/mac/.config/sketchybar.mon/items/apple.sh @@ -0,0 +1,44 @@ +#!/bin/bash + +POPUP_OFF='sketchybar --set apple.logo popup.drawing=off' +POPUP_CLICK_SCRIPT='sketchybar --set $NAME popup.drawing=toggle' + +apple_logo=( + icon=$APPLE + icon.font="$FONT:Black:16.0" + icon.color=$BLUE + padding_right=-2 + label.drawing=off + click_script="$POPUP_CLICK_SCRIPT" + popup.height=35 +) + +apple_prefs=( + icon=$PREFERENCES + label="Preferences" + click_script="open -a 'System Preferences'; $POPUP_OFF" +) + +apple_activity=( + icon=$ACTIVITY + label="Activity" + click_script="open -a 'Activity Monitor'; $POPUP_OFF" +) + +apple_lock=( + icon=$LOCK + label="Lock Screen" + click_script="pmset displaysleepnow; $POPUP_OFF" +) + +sketchybar --add item apple.logo left \ + --set apple.logo "${apple_logo[@]}" \ + \ + --add item apple.prefs popup.apple.logo \ + --set apple.prefs "${apple_prefs[@]}" \ + \ + --add item apple.activity popup.apple.logo \ + --set apple.activity "${apple_activity[@]}" \ + \ + --add item apple.lock popup.apple.logo \ + --set apple.lock "${apple_lock[@]}" diff --git a/mac/.config/sketchybar.mon/items/battery.sh b/mac/.config/sketchybar.mon/items/battery.sh new file mode 100755 index 0000000..758547b --- /dev/null +++ b/mac/.config/sketchybar.mon/items/battery.sh @@ -0,0 +1,23 @@ +#!/bin/env/bash + +battery=( + "${menu_defaults[@]}" + icon.font.size=16 + icon.font.style="Light" + label.drawing=off + update_freq=60 + popup.align=right + click_script="sketchybar --set battery popup.drawing=toggle" + script="$PLUGIN_DIR/battery.sh" + updates=when_shown +) + +sketchybar \ + --add item battery right \ + --set battery "${battery[@]}" \ + --subscribe battery power_source_change \ + mouse.entered \ + mouse.exited \ + mouse.exited.global \ + --add item battery.details popup.battery \ + --set battery.details "${menu_item_defaults[@]}" icon.drawing=off label.padding_left=0 diff --git a/mac/.config/sketchybar.mon/items/brew.sh b/mac/.config/sketchybar.mon/items/brew.sh new file mode 100755 index 0000000..4e58efd --- /dev/null +++ b/mac/.config/sketchybar.mon/items/brew.sh @@ -0,0 +1,39 @@ +#!/bin/bash + +# Trigger the brew_udpate event when brew update or upgrade is run from cmdline +# e.g. via function in .zshrc or fish function + +POPUP_CLICK_SCRIPT="sketchybar --set $NAME popup.drawing=toggle" + +brew=( + script="$PLUGIN_DIR/brew.sh" + click_script="$POPUP_CLICK_SCRIPT" + icon= + label=? + update_freq=30 + popup.align=right + popup.height=20 + icon.padding_right=-1 + padding_left=0 + padding_right=-1 + y_offset=1 +) + +brew_details=( + background.corner_radius=12 + background.padding_left=5 + background.padding_right=10 + click_script="sketchybar --set brew popup.drawing=off" +) + +sketchybar --add event brew_update \ + --add item brew right \ + --set brew "${brew[@]}" \ + \ + --subscribe brew brew_update \ + mouse.entered \ + mouse.exited \ + mouse.exited.global \ + \ + --add item brew.details popup.brew \ + --set brew.details "${brew_details[@]}" diff --git a/mac/.config/sketchybar.mon/items/cpu.sh b/mac/.config/sketchybar.mon/items/cpu.sh new file mode 100755 index 0000000..2a61f2f --- /dev/null +++ b/mac/.config/sketchybar.mon/items/cpu.sh @@ -0,0 +1,74 @@ +#!/bin/bash + +# cpu_top=( +# label.font="$FONT:Semibold:7" +# label=CPU +# icon.drawing=off +# width=0 +# padding_right=10 +# y_offset=6 +# ) +# +# cpu_percent=( +# label.font="$FONT:Heavy:12" +# label=CPU +# y_offset=-4 +# padding_right=10 +# width=55 +# icon.drawing=off +# update_freq=4 +# mach_helper="$HELPER" +# ) +# +# cpu_sys=( +# width=0 +# graph.color=$RED +# graph.fill_color=$RED +# label.drawing=off +# icon.drawing=off +# background.height=30 +# background.drawing=on +# background.color=$TRANSPARENT +# y_offset=3 +# ) +# +# cpu_user=( +# graph.color=$BLUE +# label.drawing=off +# icon.drawing=off +# background.height=30 +# background.drawing=on +# background.color=$TRANSPARENT +# background.padding_left=10 +# y_offset=3 +# ) +# +# sketchybar --add item cpu.top right \ +# --set cpu.top "${cpu_top[@]}" \ +# \ +# --add item cpu.percent right \ +# --set cpu.percent "${cpu_percent[@]}" \ +# \ +# --add graph cpu.sys right 75 \ +# --set cpu.sys "${cpu_sys[@]}" \ +# \ +# --add graph cpu.user right 75 \ +# --set cpu.user "${cpu_user[@]}" + +source "$HOME/.config/sketchybar/colors.sh" + +cpu_percent=( + label.font="$FONT:Heavy:12" + label=CPU% + label.color="$TEXT" + icon="$CPU" + icon.font.size=16 + icon.color="$BLUE" + icon.padding_right=-2 + padding_right=-2 + update_freq=2 + mach_helper="$HELPER" +) + +sketchybar --add item cpu.percent right \ + --set cpu.percent "${cpu_percent[@]}" diff --git a/mac/.config/sketchybar.mon/items/datetime.sh b/mac/.config/sketchybar.mon/items/datetime.sh new file mode 100755 index 0000000..4160a37 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/datetime.sh @@ -0,0 +1,37 @@ +#!/bin/env/bash + +sketchybar \ + --add item date right \ + --set date update_freq=60 \ + label.font="$FONT:Semibold:10" \ + align=right \ + icon.drawing=off \ + label.padding_right=4 \ + \ + width=0 \ + script='sketchybar --set $NAME label="$(date "+%a, %b %d")"' \ + click_script="open -a Calendar.app" \ + --subscribe date system_woke \ + mouse.entered \ + mouse.exited \ + mouse.exited.global \ + --add item date.details popup.date \ + --set date.details "${menu_item_defaults[@]}" \ + --add item clock right \ + --set clock update_freq=10 \ + \ + icon.drawing=off \ + label.font="$FONT:Bold:11" \ + align=right \ + label.padding_right=4 \ + popup.align=right \ + "${menu_defaults[@]}" \ + script="$PLUGIN_DIR/nextevent.sh" \ + click_script="sketchybar --set clock popup.drawing=toggle; open -a Calendar.app" \ + --subscribe clock system_woke \ + mouse.entered \ + mouse.exited \ + mouse.exited.global \ + --add item clock.details popup.clock \ + --set clock.details "${menu_item_defaults[@]}" icon.drawing=off label.padding_left=0 # y_offset=3 \ +# y_offset=-6 \ diff --git a/mac/.config/sketchybar.mon/items/disk.sh b/mac/.config/sketchybar.mon/items/disk.sh new file mode 100755 index 0000000..399427f --- /dev/null +++ b/mac/.config/sketchybar.mon/items/disk.sh @@ -0,0 +1,18 @@ +#!/bin/bash + +source "$CONFIG_DIR/colors.sh" # Loads all defined colors +source "$CONFIG_DIR/icons.sh" # Loads all defined icons + +disk=( + label.font="$FONT:Heavy:12" + label.color="$TEXT" + icon="$DISK" + icon.font="$FONT:Bold:18.0" + icon.padding_right=-2 + icon.color="$MAROON" + update_freq=60 + script="$PLUGIN_DIR/disk.sh" +) + +sketchybar --add item disk right \ + --set disk "${disk[@]}" diff --git a/mac/.config/sketchybar.mon/items/dnd.sh b/mac/.config/sketchybar.mon/items/dnd.sh new file mode 100755 index 0000000..84eaf8c --- /dev/null +++ b/mac/.config/sketchybar.mon/items/dnd.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +sketchybar \ + --add item dnd right \ + --set dnd script="$PLUGIN_DIR/dnd.sh" \ + label.drawing=off \ + --add event focus_on "_NSDoNotDisturbEnabledNotification" \ + --add event focus_off "_NSDoNotDisturbDisabledNotification" \ + --subscribe dnd focus_on focus_off mouse.clicked diff --git a/mac/.config/sketchybar.mon/items/front_app.sh b/mac/.config/sketchybar.mon/items/front_app.sh new file mode 100755 index 0000000..5839243 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/front_app.sh @@ -0,0 +1,13 @@ +#!/bin/bash + +front_app=( + label.font="$FONT:Black:12.0" + icon.background.drawing=on + display=active + script="$PLUGIN_DIR/front_app.sh" + click_script="open -a 'Mission Control'" +) + +sketchybar --add item front_app left \ + --set front_app "${front_app[@]}" \ + --subscribe front_app front_app_switched diff --git a/mac/.config/sketchybar.mon/items/github.sh b/mac/.config/sketchybar.mon/items/github.sh new file mode 100755 index 0000000..1a27fd5 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/github.sh @@ -0,0 +1,37 @@ +#!/bin/bash + +POPUP_CLICK_SCRIPT="sketchybar --set \$NAME popup.drawing=toggle" + +github_bell=( + padding_right=-5 + update_freq=180 + icon=$BELL + icon.font="$FONT:Bold:15.0" + icon.color=$BLUE + label=$LOADING + label.highlight_color=$BLUE + popup.align=right + script="$PLUGIN_DIR/github.sh" + click_script="$POPUP_CLICK_SCRIPT" +) + +github_template=( + drawing=off + background.corner_radius=12 + padding_left=7 + padding_right=7 + icon.background.height=2 + icon.background.y_offset=-12 +) + +sketchybar --add event github.update \ + --add item github.bell right \ + --set github.bell "${github_bell[@]}" \ + --subscribe github.bell mouse.entered \ + mouse.exited \ + mouse.exited.global \ + system_woke \ + github.update \ + \ + --add item github.template popup.github.bell \ + --set github.template "${github_template[@]}" diff --git a/mac/.config/sketchybar.mon/items/kakaotalk.sh b/mac/.config/sketchybar.mon/items/kakaotalk.sh new file mode 100755 index 0000000..e5c5cf5 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/kakaotalk.sh @@ -0,0 +1,18 @@ +#!/bin/bash + +kakaotalk=( + "${notification_defaults[@]}" + icon= + icon.font.size=13 + background.color=$YELLOW + script="$PLUGIN_DIR/kakaotalk.sh" + click_script="open -a /System/Applications/KakaoTalk.app" + icon.padding_left=7 + icon.padding_right=2 + label.padding_right=7 + background.padding_right=5 + background.height=20 +) + +sketchybar --add item kakaotalk right \ + --set kakaotalk "${kakaotalk[@]}" diff --git a/mac/.config/sketchybar.mon/items/keyboard.sh b/mac/.config/sketchybar.mon/items/keyboard.sh new file mode 100755 index 0000000..bffaf52 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/keyboard.sh @@ -0,0 +1,14 @@ +#!/bin/bash + +keyboard=( + padding_right=4 + icon.drawing=off + script="$PLUGIN_DIR/keyboard.sh" + icon.color=$GREY + icon.font="$FONT:Regular:14.0" +) + +sketchybar --add item keyboard right \ + --set keyboard "${keyboard[@]}" \ + --add event keyboard_change "AppleSelectedInputSourcesChangedNotification" \ + --subscribe keyboard keyboard_change diff --git a/mac/.config/sketchybar.mon/items/mail.sh b/mac/.config/sketchybar.mon/items/mail.sh new file mode 100755 index 0000000..590d52b --- /dev/null +++ b/mac/.config/sketchybar.mon/items/mail.sh @@ -0,0 +1,19 @@ +#!/bin/env/bash + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +mail=( + "${notification_defaults[@]}" + icon= + icon.y_offset=1 + background.color=$YELLOW + background.height=18 + icon.padding_left=6 + label.padding_right=6 + script="$PLUGIN_DIR/mail.sh" + click_script="open -a /System/Applications/Mail.app" +) + +sketchybar --add item mail right \ + --set mail "${mail[@]}" diff --git a/mac/.config/sketchybar.mon/items/memory.sh b/mac/.config/sketchybar.mon/items/memory.sh new file mode 100755 index 0000000..5ff38ca --- /dev/null +++ b/mac/.config/sketchybar.mon/items/memory.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +source "$CONFIG_DIR/colors.sh" # Loads all defined colors +source "$CONFIG_DIR/icons.sh" # Loads all defined icons + +memory=( + label.font="$FONT:Heavy:12" + label.color="$TEXT" + icon="$MEMORY" + icon.font="$FONT:Bold:16.0" + icon.font.size=20 + icon.color="$GREEN" + update_freq=15 + script="$PLUGIN_DIR/memory.sh" + icon.padding_right=-2 + padding_right=-2 +) + +sketchybar --add item memory right \ + --set memory "${memory[@]}" diff --git a/mac/.config/sketchybar.mon/items/messages.sh b/mac/.config/sketchybar.mon/items/messages.sh new file mode 100755 index 0000000..9ad9513 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/messages.sh @@ -0,0 +1,13 @@ +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +messages=( + "${notification_defaults[@]}" + icon= + background.color=$GREEN + script="$PLUGIN_DIR/messages.sh" + click_script="open -a /System/Applications/Messages.app" +) + +sketchybar --add item messages right \ + --set messages "${messages[@]}"
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/items/mic.sh b/mac/.config/sketchybar.mon/items/mic.sh new file mode 100755 index 0000000..666af0e --- /dev/null +++ b/mac/.config/sketchybar.mon/items/mic.sh @@ -0,0 +1,5 @@ +sketchybar -m --add item mic right \ + --set mic update_freq=3 \ + --set mic script="$PLUGIN_DIR/mic.sh" \ + --set mic click_script="$PLUGIN_DIR/mic_click.sh" \ + padding_right=-8 diff --git a/mac/.config/sketchybar.mon/items/music.sh b/mac/.config/sketchybar.mon/items/music.sh new file mode 100755 index 0000000..3730d88 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/music.sh @@ -0,0 +1,36 @@ +#!/bin/env/bash + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +music=( + "${bracket_defaults[@]}" + script="$PLUGIN_DIR/music.sh" + popup.align=center + padding_left=0 + label.padding_right=$PADDINGS + padding_right=$(($PADDINGS * 2)) + icon= + drawing=off + label="Loading…" + background.image=media.artwork + background.image.scale=0.75 + background.image.corner_radius=$PADDINGS + icon.padding_left=48 + label.max_chars=33 + updates=on + --subscribe music media_change + --subscribe music mouse.entered + mouse.clicked + mouse.exited + mouse.exited.global +) + +sketchybar \ + --add item music center \ + --set music "${music[@]}" \ + --set music "${menu_defaults[@]}" \ + --add item music.cover popup.music \ + --add item music.artist popup.music \ + --add item music.title popup.music \ + --add item music.album popup.music diff --git a/mac/.config/sketchybar.mon/items/network.sh b/mac/.config/sketchybar.mon/items/network.sh new file mode 100755 index 0000000..93bf083 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/network.sh @@ -0,0 +1,40 @@ +#!/bin/bash + +source "$CONFIG_DIR/globalstyles.sh" + +network_down=( + y_offset=-9 + label.font="$FONT:Heavy:10" + label.color="$TEXT" + icon="$NETWORK_DOWN" + icon.font="$NERD_FONT:Bold:16.0" + icon.font.size=15 + icon.color="$GREEN" + icon.highlight_color="$BLUE" + icon.padding_right=2 + padding_right=-2 + update_freq=1 + icon.y_offset=1 +) + +network_up=( + background.padding_right=-65 + y_offset=5 + label.font="$FONT:Heavy:10" + label.color="$TEXT" + label.padding_right=5 + icon="$NETWORK_UP" + icon.font="$NERD_FONT:Bold:16.0" + icon.font.size=15 + icon.color="$GREEN" + icon.highlight_color="$BLUE" + icon.padding_right=2 + icon.y_offset=1 + update_freq=1 + script="$PLUGIN_DIR/network.sh" +) + +sketchybar --add item network.down right \ + --set network.down "${network_down[@]}" \ + --add item network.up right \ + --set network.up "${network_up[@]}" diff --git a/mac/.config/sketchybar.mon/items/package_monitor.sh b/mac/.config/sketchybar.mon/items/package_monitor.sh new file mode 100755 index 0000000..89be3a2 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/package_monitor.sh @@ -0,0 +1,19 @@ +#!/bin/bash + +# Trigger the package_monitor_udpate event when package_monitor update or upgrade is run from cmdline +# e.g. via function in .zshrc + +package_monitor=( + icon= + icon.font.size=12 + icon.padding_right=-1 + label=? + script="$PLUGIN_DIR/package_monitor.sh" + padding_left=-2 +) + +sketchybar --add event package_monitor_update \ + --add item package_monitor right \ + --set package_monitor "${package_monitor[@]}" \ + --subscribe package_monitor package_monitor_update \ + mouse.clicked diff --git a/mac/.config/sketchybar.mon/items/separator_right.sh b/mac/.config/sketchybar.mon/items/separator_right.sh new file mode 100755 index 0000000..13a6b7f --- /dev/null +++ b/mac/.config/sketchybar.mon/items/separator_right.sh @@ -0,0 +1,13 @@ +#!/usr/bin/env bash + +separator_right=( + icon= + icon.font="$FONT:Regular:25.0" + label.drawing=off + click_script='sketchybar --trigger toggle_stats' + icon.color="$TEXT" + padding_right=10 +) + +sketchybar --add item separator_right right \ + --set separator_right "${separator_right[@]}" diff --git a/mac/.config/sketchybar.mon/items/spaces.sh b/mac/.config/sketchybar.mon/items/spaces.sh new file mode 100755 index 0000000..5dc28d0 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/spaces.sh @@ -0,0 +1,56 @@ +#!/bin/bash + +source "$CONFIG_DIR/globalstyles.sh" + +SPACE_ICONS=("1" "2" "3" "4" "5" "6" "7" "8" "9" "10" "11" "12") + +# Destroy space on right click, focus space on left click. +# New space by left clicking separator (>) + +sid=0 +spaces=() +for i in "${!SPACE_ICONS[@]}"; do + sid=$(($i + 1)) + + space=( + space=$sid + icon="${SPACE_ICONS[i]}" + icon.padding_left=2 + icon.padding_right=-5 + label.padding_right=10 + label.font="sketchybar-app-font:Regular:16.0" + label.y_offset=-1 + background.height=2 + script="$PLUGIN_DIR/space.sh" + ) + + sketchybar --add space space.$sid left \ + --set space.$sid "${space[@]}" \ + --subscribe space.$sid mouse.clicked +done + +spaces=( + background.color=$BACKGROUND_1 + background.border_color=$BACKGROUND_2 + background.border_width=2 + background.drawing=on +) + +space_creator=( + icon= + icon.font="$FONT:Heavy:25.0" + padding_left=2 + padding_right=5 + label.drawing=off + display=active + script="$PLUGIN_DIR/space_windows.sh" + associated_display=active + click_script='yabai -m space --create && sketchybar --trigger space_change' + icon.color=$WHITE +) + +sketchybar --add bracket spaces '/space\..*/' \ + --set spaces "${spaces[@]}" \ + --add item space_creator left \ + --set space_creator "${space_creator[@]}" \ + --subscribe space_creator space_windows_change diff --git a/mac/.config/sketchybar.mon/items/spotify.sh b/mac/.config/sketchybar.mon/items/spotify.sh new file mode 100755 index 0000000..421e299 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/spotify.sh @@ -0,0 +1,201 @@ +#!/bin/bash + +SPOTIFY_EVENT="com.spotify.client.PlaybackStateChanged" +POPUP_SCRIPT="sketchybar -m --set spotify.anchor popup.drawing=toggle" + +spotify_anchor=( + script="$PLUGIN_DIR/spotify.sh" + click_script="$POPUP_SCRIPT" + popup.horizontal=on + popup.align=center + popup.height=150 + icon= + icon.font="$FONT:Regular:25.0" + label.drawing=off + drawing=off +) + +spotify_cover=( + script="$PLUGIN_DIR/spotify.sh" + click_script="open -a 'Spotify'; $POPUP_SCRIPT" + label.drawing=off + icon.drawing=off + padding_left=12 + padding_right=10 + background.image.scale=0.2 + background.image.drawing=on + background.drawing=on + background.image.corner_radius=9 + shadow=on +) + +spotify_title=( + icon.drawing=off + padding_left=0 + padding_right=0 + width=0 + label.font="$FONT:Heavy:15.0" + label.max_chars=20 + y_offset=55 +) + +spotify_artist=( + icon.drawing=off + y_offset=30 + padding_left=0 + padding_right=0 + width=0 + label.max_chars=20 +) + +spotify_album=( + icon.drawing=off + padding_left=0 + padding_right=0 + y_offset=15 + width=0 + label.max_chars=25 +) + +spotify_state=( + icon.drawing=on + icon.font="$FONT:Light Italic:10.0" + icon.width=35 + icon="00:00" + label.drawing=on + label.font="$FONT:Light Italic:10.0" + label.width=35 + label="00:00" + padding_left=0 + padding_right=0 + y_offset=-15 + width=0 + slider.background.height=6 + slider.background.corner_radius=1 + slider.background.color=$GREY + slider.highlight_color=$GREEN + slider.percentage=40 + slider.width=115 + script="$PLUGIN_DIR/spotify.sh" + update_freq=1 + updates=when_shown +) + +spotify_shuffle=( + icon= + icon.padding_left=5 + icon.padding_right=5 + icon.color=$BLACK + icon.highlight_color=$GREY + label.drawing=off + script="$PLUGIN_DIR/spotify.sh" + y_offset=-45 +) + +spotify_back=( + icon= + icon.padding_left=5 + icon.padding_right=5 + icon.color=$BLACK + script="$PLUGIN_DIR/spotify.sh" + label.drawing=off + y_offset=-45 +) + +spotify_play=( + icon= + background.height=40 + background.corner_radius=20 + width=40 + align=center + background.color=$POPUP_BACKGROUND_COLOR + background.border_color=$WHITE + background.border_width=0 + background.drawing=on + icon.padding_left=4 + icon.padding_right=5 + updates=on + label.drawing=off + script="$PLUGIN_DIR/spotify.sh" + y_offset=-45 +) + +spotify_next=( + icon= + icon.padding_left=5 + icon.padding_right=5 + icon.color=$BLACK + label.drawing=off + script="$PLUGIN_DIR/spotify.sh" + y_offset=-45 +) + +spotify_repeat=( + icon= + icon.highlight_color=$GREY + icon.padding_left=5 + icon.padding_right=10 + icon.color=$BLACK + label.drawing=off + script="$PLUGIN_DIR/spotify.sh" + y_offset=-45 +) + +spotify_controls=( + background.color=$GREEN + background.corner_radius=11 + background.drawing=on + y_offset=-45 +) + +sketchybar --add event spotify_change $SPOTIFY_EVENT \ + --add item spotify.anchor center \ + --set spotify.anchor "${spotify_anchor[@]}" \ + --subscribe spotify.anchor mouse.entered mouse.exited \ + mouse.exited.global \ + \ + --add item spotify.cover popup.spotify.anchor \ + --set spotify.cover "${spotify_cover[@]}" \ + \ + --add item spotify.title popup.spotify.anchor \ + --set spotify.title "${spotify_title[@]}" \ + \ + --add item spotify.artist popup.spotify.anchor \ + --set spotify.artist "${spotify_artist[@]}" \ + \ + --add item spotify.album popup.spotify.anchor \ + --set spotify.album "${spotify_album[@]}" \ + \ + --add slider spotify.state popup.spotify.anchor \ + --set spotify.state "${spotify_state[@]}" \ + --subscribe spotify.state mouse.clicked \ + \ + --add item spotify.shuffle popup.spotify.anchor \ + --set spotify.shuffle "${spotify_shuffle[@]}" \ + --subscribe spotify.shuffle mouse.clicked \ + \ + --add item spotify.back popup.spotify.anchor \ + --set spotify.back "${spotify_back[@]}" \ + --subscribe spotify.back mouse.clicked \ + \ + --add item spotify.play popup.spotify.anchor \ + --set spotify.play "${spotify_play[@]}" \ + --subscribe spotify.play mouse.clicked spotify_change \ + \ + --add item spotify.next popup.spotify.anchor \ + --set spotify.next "${spotify_next[@]}" \ + --subscribe spotify.next mouse.clicked \ + \ + --add item spotify.repeat popup.spotify.anchor \ + --set spotify.repeat "${spotify_repeat[@]}" \ + --subscribe spotify.repeat mouse.clicked \ + \ + --add item spotify.spacer popup.spotify.anchor \ + --set spotify.spacer width=5 \ + \ + --add bracket spotify.controls spotify.shuffle \ + spotify.back \ + spotify.play \ + spotify.next \ + spotify.repeat \ + --set spotify.controls "${spotify_controls[@]}" diff --git a/mac/.config/sketchybar.mon/items/svim.sh b/mac/.config/sketchybar.mon/items/svim.sh new file mode 100755 index 0000000..502343d --- /dev/null +++ b/mac/.config/sketchybar.mon/items/svim.sh @@ -0,0 +1,14 @@ +#!/bin/bash + +svim=( + script="$PLUGIN_DIR/svim.sh" + icon=$INSERT_MODE + icon.font.size=20 + updates=on + drawing=off +) + +sketchybar --add event svim_update \ + --add item svim right \ + --set svim "${svim[@]}" \ + --subscribe svim svim_update diff --git a/mac/.config/sketchybar.mon/items/system.sh b/mac/.config/sketchybar.mon/items/system.sh new file mode 100755 index 0000000..dc74f73 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/system.sh @@ -0,0 +1,53 @@ +### mem Widget ### +sketchybar --add item mem right \ + --set mem update_freq=10 \ + icon="asdf" \ + icon.font="Font Awesome 6 Free:Solid:15.4" \ + icon.padding_right=4 \ + icon.color=0xfff5c1e6 \ + icon.y_offset=-3 \ + label.y_offset=-3 \ + label.font="$FONT:Medium:19.0" \ + label.color=0xff47455c \ + label.padding_right=8 \ + background.drawing=on \ + background.color=0xfff4f5f8 \ + script="$PLUGIN_DIR/mem.sh" + +# ### cpu Widget ### +# sketchybar --add item cpu right \ +# --set cpu update_freq=10 \ +# icon.font="Font Awesome 6 Free:Solid:15.4" \ +# icon.padding_right=4 \ +# icon.color=0xffedd6a4 \ +# icon.y_offset=-3 \ +# label.y_offset=-3 \ +# label.font="$FONT:Medium:19.0" \ +# label.color=0xff47455c \ +# label.padding_right=8 \ +# background.drawing=on \ +# background.color=0xfff4f5f8 \ +# script="$PLUGIN_DIR/cpu.sh" \ + +### ssd Widget ### +sketchybar --add item disk right \ + --set disk update_freq=10 \ + icon="asdf" \ + icon.font="Font Awesome 6 Free:Solid:15.4" \ + icon.padding_right=4 \ + icon.color=0xfff37ea0 \ + icon.y_offset=-3 \ + label.y_offset=-3 \ + label.font="$FONT:Medium:19.0" \ + label.color=0xff47455c \ + label.padding_right=8 \ + background.drawing=on \ + background.color=0xfff4f5f8 \ + script="$PLUGIN_DIR/disk.sh" + +# sketchybar --add item collapse right \ +# --set collapse icon="" \ +# icon.font="Font Awesome 6 Free:Solid:20.0" \ +# icon.color=0xff47455c \ +# icon.y_offset=-3 \ +# click_script="$PLUGIN_DIR/collapse.sh" diff --git a/mac/.config/sketchybar.mon/items/thunderbird.sh b/mac/.config/sketchybar.mon/items/thunderbird.sh new file mode 100755 index 0000000..234b038 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/thunderbird.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +thunderbird=( + "${notification_defaults[@]}" + icon= + icon.font.size=17 + icon.color=$OSBLUE + icon.y_offset=0 + background.color=$WHITE + script="$PLUGIN_DIR/thunderbird.sh" + click_script="open -a /System/Applications/Thunderbird.app" + icon.padding_left=7 + icon.padding_right=-1 + label.padding_right=7 + background.padding_right=5 + background.height=20 +) + +sketchybar --add item thunderbird right \ + --set thunderbird "${thunderbird[@]}" diff --git a/mac/.config/sketchybar.mon/items/toggle_stats.sh b/mac/.config/sketchybar.mon/items/toggle_stats.sh new file mode 100755 index 0000000..301e0e4 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/toggle_stats.sh @@ -0,0 +1,11 @@ +#!/bin/bash + +sketchybar --add event hide_stats \ + --add event show_stats \ + --add event toggle_stats \ + \ + --add item animator right \ + --set animator drawing=off \ + updates=on \ + script="$PLUGIN_DIR/toggle_stats.sh" \ + --subscribe animator hide_stats show_stats toggle_stats diff --git a/mac/.config/sketchybar.mon/items/volume.sh b/mac/.config/sketchybar.mon/items/volume.sh new file mode 100755 index 0000000..a8efdd5 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/volume.sh @@ -0,0 +1,35 @@ +#!/bin/bash + +volume_slider=( + script="$PLUGIN_DIR/volume.sh" + updates=on + label.drawing=off + icon.drawing=off + slider.highlight_color=$BLUE + slider.background.height=5 + slider.background.corner_radius=3 + slider.background.color=$BACKGROUND_2 + slider.knob= + slider.knob.drawing=on + padding_left=-5 + padding_right=-1 +) + +volume_icon=( + click_script="$PLUGIN_DIR/volume_click.sh" + icon=$VOLUME_100 + icon.width=0 + icon.align=left + icon.font="$FONT:Regular:14.0" + label.width=25 + label.align=left + label.font="$FONT:Regular:14.0" +) + +sketchybar --add slider volume right \ + --set volume "${volume_slider[@]}" \ + --subscribe volume volume_change \ + mouse.clicked \ + \ + --add item volume_icon right \ + --set volume_icon "${volume_icon[@]}" diff --git a/mac/.config/sketchybar.mon/items/weather.sh b/mac/.config/sketchybar.mon/items/weather.sh new file mode 100755 index 0000000..287354d --- /dev/null +++ b/mac/.config/sketchybar.mon/items/weather.sh @@ -0,0 +1,23 @@ +#!/bin/bash + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +weather=( + script="$PLUGIN_DIR/weather.sh" + "${menu_defaults[@]}" + popup.align=right + update_freq=300 + updates=on + click_script="sketchybar --set $NAME popup.drawing=toggle; open -a /System/Applications/Weather.app" + --subscribe weather wifi_change + mouse.entered + mouse.exited + mouse.exited.global +) + +sketchybar \ + --add item weather right \ + --set weather "${weather[@]}" \ + --add item weather.details popup.weather \ + --set weather.details "${menu_item_defaults[@]}" icon.drawing=off diff --git a/mac/.config/sketchybar.mon/items/wifi.sh b/mac/.config/sketchybar.mon/items/wifi.sh new file mode 100755 index 0000000..a903c23 --- /dev/null +++ b/mac/.config/sketchybar.mon/items/wifi.sh @@ -0,0 +1,39 @@ +#!/bin/bash + +POPUP_OFF="sketchybar --set wifi popup.drawing=off" + +wifi=( + "${menu_defaults[@]}" + icon="$WIFI_DISCONNECTED" + script="$PLUGIN_DIR/wifi.sh" + label.drawing=off + click_script="$POPUP_CLICK_SCRIPT" + popup.align=right + updates=when_shown + update_freq=5 + --subscribe wifi wifi_change + mouse.entered + mouse.exited + mouse.exited.global + icon.padding_left=-3 +) + +sketchybar \ + --add item wifi right \ + --set wifi "${wifi[@]}" \ + --add item wifi.ssid popup.wifi \ + --set wifi.ssid icon= \ + label="SSID" \ + "${menu_item_defaults[@]}" \ + click_script="open 'x-apple.systempreferences:com.apple.preference.network?Wi-Fi';$POPUP_OFF" \ + --add item wifi.strength popup.wifi \ + --set wifi.strength icon= \ + label="Speed" \ + "${menu_item_defaults[@]}" \ + click_script="open 'x-apple.systempreferences:com.apple.preference.network?Wi-Fi';$POPUP_OFF" \ + --add item wifi.ipaddress popup.wifi \ + --set wifi.ipaddress icon= \ + label="IP Address" \ + "${menu_item_defaults[@]}" \ + click_script="echo \"$IP_ADDRESS\"|pbcopy;$POPUP_OFF" \ + --subscribe wifi wifi_change mouse.clicked diff --git a/mac/.config/sketchybar.mon/items/yabai.sh b/mac/.config/sketchybar.mon/items/yabai.sh new file mode 100755 index 0000000..c123a8b --- /dev/null +++ b/mac/.config/sketchybar.mon/items/yabai.sh @@ -0,0 +1,21 @@ +#!/bin/bash + +yabai=( + icon=$YABAI_GRID + label.drawing=off + script="$PLUGIN_DIR/yabai.sh" + icon.font="$FONT:Bold:14.0" + icon.color="$FLAMINGO" + padding_left=-2 + padding_right=0 +) + +sketchybar --add event window_focus \ + --add event windows_on_spaces \ + --add item yabai left \ + --set yabai "${yabai[@]}" \ + --subscribe yabai window_focus \ + space_change \ + windows_on_spaces \ + mouse.scrolled.global \ + mouse.clicked diff --git a/mac/.config/sketchybar.mon/plugins/battery.sh b/mac/.config/sketchybar.mon/plugins/battery.sh new file mode 100755 index 0000000..60a8dc4 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/battery.sh @@ -0,0 +1,85 @@ +#!/bin/bash + +source "$CONFIG_DIR/colors.sh" + +render_item() { + + PERCENTAGE=$(pmset -g batt | grep -Eo "\d+%" | cut -d% -f1) + CHARGING=$(pmset -g batt | grep 'AC Power') + CHARGING_STATUS="Not charging" + + if [ $PERCENTAGE = "" ]; then + exit 0 + fi + + COLOR=$LABEL_COLOR + ICON="" + + case ${PERCENTAGE} in + 9[0-9]) + ICON="" + ;; + 8[0-9]) + ICON="" + ;; + 7[0-9]) + ICON="" + ;; + 6[0-9]) + ICON="" + ;; + 5[0-9]) + ICON="" + ;; + 4[0-9]) + ICON="" + ;; + 3[0-9]) + ICON="" + ;; + 2[0-9]) + ICON="" + ;; + 1[0-9]) + ICON="" + ;; + *) + ICON="" + COLOR=$RED + ;; + esac + + if [[ $CHARGING != "" ]]; then + ICON="" + CHARGING_STATUS="Charging" + COLOR=$LABEL_COLOR + fi + + sketchybar --set battery icon=$ICON + +} + +render_popup() { + sketchybar --set battery.details label="$PERCENTAGE% (${CHARGING_STATUS})" +} + +update() { + render_item + render_popup +} + +popup() { + sketchybar --set "$NAME" popup.drawing="$1" +} + +case "$SENDER" in +"routine" | "forced" | "power_source_change") + update + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/brew.sh b/mac/.config/sketchybar.mon/plugins/brew.sh new file mode 100755 index 0000000..308fd78 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/brew.sh @@ -0,0 +1,104 @@ +#!/bin/bash + +source "$CONFIG_DIR/globalstyles.sh" + +PREV_COUNT=$(sketchybar --query brew | jq -r .popup.items | grep ".package*" -c) + +render_bar_item() { + case "$COUNT" in + [3-5][0-9]) + COLOR=$MAROON + ;; + [1-2][0-9]) + COLOR=$PEACH + ;; + [1-9]) + COLOR=$YELLOW + ;; + 0) + COLOR=$GREEN + COUNT= + ;; + esac + + sketchybar --set "$NAME" label="$COUNT" label.color="$COLOR" icon.color="$COLOR" +} + +add_outdated_header() { + brew_header=( + label="$(echo -e 'Outdated Brews')" + label.font="$FONT:Bold:14.0" + label.align=left + icon.drawing=off + click_script="sketchybar --set $NAME popup.drawing=off" + ) + + sketchybar --set brew.details "${brew_header[@]}" + +} + +render_popup() { + add_outdated_header + + COUNTER=0 + sketchybar --remove '/brew.package\.*/' + + if [[ -n "$OUTDATED" ]]; then + while IFS= read -r package; do + + brew_package=( + label="$package" + label.align=right + label.padding_left=20 + icon.drawing=off + click_script="sketchybar --set $NAME popup.drawing=off" + + ) + item=brew.package."$COUNTER" + + sketchybar --add item "$item" popup."$NAME" \ + --set "$item" "${brew_package[@]}" + + COUNTER=$((COUNTER + 1)) + + done <<<"$(echo -n "$OUTDATED" | grep '^')" + fi +} + +update() { + brew update + COLOR=$RED + OUTDATED=$(brew outdated) + COUNT=$(echo -n "$OUTDATED" | grep -c '^') + + render_bar_item + render_popup + + if [ "$COUNT" -ne "$PREV_COUNT" ] 2>/dev/null || [ "$SENDER" = "forced" ]; then + sketchybar --animate tanh 15 --set "$NAME" + fi +} + +popup() { + if [[ "$PREV_COUNT" -gt 0 ]]; then + sketchybar --set "$NAME" popup.drawing="$1" + else + sketchybar --set "$NAME" popup.drawing=off + fi + +} + +case "$SENDER" in +"routine" | "forced") + update + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +"mouse.clicked") + popup toggle + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/disk.sh b/mac/.config/sketchybar.mon/plugins/disk.sh new file mode 100755 index 0000000..f2adc30 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/disk.sh @@ -0,0 +1,29 @@ +#!/bin/bash + +source "$CONFIG_DIR/globalstyles.sh" + +COUNT="$(df -H | grep -E '^(/dev/disk3s5)' | awk '{ printf ("%s\n", $5) }' | sed 's/%//')" + +COLOR=$RED + +case "$COUNT" in +[7-8][0-9]) # 70-89% + COLOR=$PEACH + ;; +[5-6][0-9]) # 50-69% + COLOR=$YELLOW + ;; +[3-4][0-9]) # 20-49% + COLOR=$GREEN + ;; +[1-2][0-9]) # 10-19% + COLOR=$LAVENDER + ;; +[0-9]) # 0-9% + COLOR=$WHITE + ;; +esac + +sketchybar -m --set "$NAME" \ + label="$COUNT%" \ + icon.color=$COLOR diff --git a/mac/.config/sketchybar.mon/plugins/dnd.sh b/mac/.config/sketchybar.mon/plugins/dnd.sh new file mode 100755 index 0000000..42c7ba6 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/dnd.sh @@ -0,0 +1,33 @@ +#!/bin/sh + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +update() { + dnd_enabled=$(cat ~/Library/DoNotDisturb/DB/Assertions.json | jq .data[0].storeAssertionRecords) + # alternate method: defaults read com.apple.controlcenter "NSStatusItem Visible FocusModes" + ICON= + + if [ "$dnd_enabled" = "null" ]; then + COLOR=$WHITE_25 + # echo $NAME: "Disabled" + else + COLOR=$WHITE + # echo $NAME: "Enabled" + fi + + sketchybar --set $NAME icon=$ICON icon.color=$COLOR +} + +toggle() { + osascript -e 'tell application "System Events" to keystroke "\\" using {control down, shift down, command down, option down}' +} + +case "$SENDER" in +"routine" | "forced" | "focus_on" | "focus_off") + update + ;; +"mouse.clicked") + toggle + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/dndindicator.sh b/mac/.config/sketchybar.mon/plugins/dndindicator.sh new file mode 100755 index 0000000..0dd05e8 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/dndindicator.sh @@ -0,0 +1,24 @@ +#!/usr/bin/env bash + +# Thanks to reddit:rudypaul +# BIN_DIR="/usr/bin" + +# PLUTIL="${BIN_DIR}/plutil" +# XPATH="${BIN_DIR}/xpath" +# BASE64="${BIN_DIR}/base64" + +dnd_enabled=$( +defaults read com.apple.controlcenter "NSStatusItem Visible FocusModes" +# dnd_enabled=$( +# "${PLUTIL}" -extract dnd_prefs xml1 -o - ~/Library/Preferences/com.apple.ncprefs.plist | +# "${XPATH}" -q -e 'string(//data)' | +# "${BASE64}" -D | +# "${PLUTIL}" -convert xml1 - -o - | +# "${XPATH}" -q -e 'boolean(//key[text()="userPref"]/following-sibling::dict/key[text()="enabled"])' +) + +if [ $dnd_enabled -eq 1 ]; then + sketchybar --set $NAME drawing=on icon= +else + sketchybar --set $NAME drawing=off icon= +fi
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/front_app.sh b/mac/.config/sketchybar.mon/plugins/front_app.sh new file mode 100755 index 0000000..066efb0 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/front_app.sh @@ -0,0 +1,8 @@ +#!/bin/bash + +if [ "$SENDER" = "front_app_switched" ]; then + # Set the app name and app icon and then animate a bounce for the icon size + sketchybar --set $NAME label="$INFO" icon.background.image="app.$INFO" \ + --animate tanh 10 --set $NAME icon.background.image.scale=0.8 \ + icon.background.image.scale=0.55 +fi diff --git a/mac/.config/sketchybar.mon/plugins/github.sh b/mac/.config/sketchybar.mon/plugins/github.sh new file mode 100755 index 0000000..bf09991 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/github.sh @@ -0,0 +1,108 @@ +#!/bin/bash + +update() { + source "$CONFIG_DIR/colors.sh" + source "$CONFIG_DIR/icons.sh" + + NOTIFICATIONS="$(gh api notifications)" + COUNT="$(echo "$NOTIFICATIONS" | jq 'length')" + args=() + if [ "$NOTIFICATIONS" = "[]" ]; then + args+=(--set $NAME icon=$BELL label="0") + else + args+=(--set $NAME icon=$BELL_DOT label="$COUNT") + fi + + PREV_COUNT=$(sketchybar --query github.bell | jq -r .label.value) + # For sound to play around with: + # afplay /System/Library/Sounds/Morse.aiff + + args+=(--remove '/github.notification\.*/') + + COUNTER=0 + COLOR=$BLUE + args+=(--set github.bell icon.color=$COLOR) + + while read -r repo url type title; do + COUNTER=$((COUNTER + 1)) + IMPORTANT="$(echo "$title" | egrep -i "(deprecat|break|broke)")" + COLOR=$BLUE + PADDING=0 + + if [ "${repo}" = "" ] && [ "${title}" = "" ]; then + repo="Note" + title="No new notifications" + fi + case "${type}" in + "'Issue'") + COLOR=$GREEN + ICON=$GIT_ISSUE + URL="$(gh api "$(echo "${url}" | sed -e "s/^'//" -e "s/'$//")" | jq .html_url)" + ;; + "'Discussion'") + COLOR=$WHITE + ICON=$GIT_DISCUSSION + URL="https://www.github.com/notifications" + ;; + "'PullRequest'") + COLOR=$MAGENTA + ICON=$GIT_PULL_REQUEST + URL="$(gh api "$(echo "${url}" | sed -e "s/^'//" -e "s/'$//")" | jq .html_url)" + ;; + "'Commit'") + COLOR=$WHITE + ICON=$GIT_COMMIT + URL="$(gh api "$(echo "${url}" | sed -e "s/^'//" -e "s/'$//")" | jq .html_url)" + ;; + esac + + if [ "$IMPORTANT" != "" ]; then + COLOR=$RED + ICON= + args+=(--set github.bell icon.color=$COLOR) + fi + + notification=( + label="$(echo "$title" | sed -e "s/^'//" -e "s/'$//")" + icon="$ICON $(echo "$repo" | sed -e "s/^'//" -e "s/'$//"):" + icon.padding_left="$PADDING" + label.padding_right="$PADDING" + icon.color=$COLOR + position=popup.github.bell + icon.background.color=$COLOR + drawing=on + click_script="open \"$URL\"; sketchybar --set github.bell popup.drawing=off; sleep 5; sketchybar --trigger github.update" + ) + + args+=(--clone github.notification.$COUNTER github.template + --set github.notification.$COUNTER "${notification[@]}") + done <<<"$(echo "$NOTIFICATIONS" | jq -r '.[] | [.repository.name, .subject.latest_comment_url, .subject.type, .subject.title] | @sh')" + + sketchybar -m "${args[@]}" >/dev/null + + if [ $COUNT -gt $PREV_COUNT ] 2>/dev/null || [ "$SENDER" = "forced" ]; then + sketchybar --animate tanh 15 --set github.bell label.y_offset=5 label.y_offset=0 + fi +} + +popup() { + sketchybar --set $NAME popup.drawing=$1 +} + +case "$SENDER" in +"routine" | "forced" | "github.update") + update + ;; +"system_woke") + sleep 10 && update # Wait for network to connect + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +"mouse.clicked") + popup toggle + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/icon_map.sh b/mac/.config/sketchybar.mon/plugins/icon_map.sh new file mode 100755 index 0000000..1b2f82a --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/icon_map.sh @@ -0,0 +1,486 @@ +#!/bin/bash + +function icon_map() { + case "$1" in + "Typora") + icon_result=":text:" + ;; + "Orion" | "Orion RC") + icon_result=":orion:" + ;; + "Grammarly Editor") + icon_result=":grammarly:" + ;; + "kitty") + icon_result=":kitty:" + ;; + "ClickUp") + icon_result=":click_up:" + ;; + "Iris") + icon_result=":iris:" + ;; + "PomoDone App") + icon_result=":pomodone:" + ;; + "qutebrowser") + icon_result=":qute_browser:" + ;; + "Raindrop.io") + icon_result=":raindrop_io:" + ;; + "Airmail") + icon_result=":airmail:" + ;; + "Affinity Publisher 2") + icon_result=":affinity_publisher_2:" + ;; + "Calendar" | "日历" | "Fantastical" | "Cron" | "Amie") + icon_result=":calendar:" + ;; + "Figma") + icon_result=":figma:" + ;; + "Element") + icon_result=":element:" + ;; + "Signal") + icon_result=":signal:" + ;; + "Mattermost") + icon_result=":mattermost:" + ;; + "Caprine") + icon_result=":caprine:" + ;; + "Microsoft To Do" | "Things") + icon_result=":things:" + ;; + "Godot") + icon_result=":godot:" + ;; + "Android Messages") + icon_result=":android_messages:" + ;; + "Zed") + icon_result=":zed:" + ;; + "Anytype") + icon_result=":anytype:" + ;; + "TeamSpeak 3") + icon_result=":team_speak:" + ;; + "LibreWolf") + icon_result=":libre_wolf:" + ;; + "Neovide" | "neovide") + icon_result=":neovide:" + ;; + "Spotlight") + icon_result=":spotlight:" + ;; + "微信") + icon_result=":wechat:" + ;; + "Dropbox") + icon_result=":dropbox:" + ;; + "Transmit") + icon_result=":transmit:" + ;; + "TickTick") + icon_result=":tick_tick:" + ;; + "Parallels Desktop") + icon_result=":parallels:" + ;; + "Audacity") + icon_result=":audacity:" + ;; + "Rider" | "JetBrains Rider") + icon_result=":rider:" + ;; + "DEVONthink 3") + icon_result=":devonthink3:" + ;; + "Docker" | "Docker Desktop") + icon_result=":docker:" + ;; + "Matlab") + icon_result=":matlab:" + ;; + "VLC") + icon_result=":vlc:" + ;; + "Alacritty") + icon_result=":alacritty:" + ;; + "Pages" | "Pages 文稿") + icon_result=":pages:" + ;; + "Bear") + icon_result=":bear:" + ;; + "Pine") + icon_result=":pine:" + ;; + "Affinity Designer 2") + icon_result=":affinity_designer_2:" + ;; + "Keyboard Maestro") + icon_result=":keyboard_maestro:" + ;; + "Joplin") + icon_result=":joplin:" + ;; + "mpv") + icon_result=":mpv:" + ;; + "zoom.us") + icon_result=":zoom:" + ;; + "Affinity Photo 2") + icon_result=":affinity_photo_2:" + ;; + "Music" | "音乐") + icon_result=":music:" + ;; + "League of Legends") + icon_result=":league_of_legends:" + ;; + "Tor Browser") + icon_result=":tor_browser:" + ;; + "Hyper") + icon_result=":hyper:" + ;; + "WhatsApp") + icon_result=":whats_app:" + ;; + "카카오톡") + icon_result=":kakaotalk:" + ;; + "Discord" | "Discord Canary" | "Discord PTB") + icon_result=":discord:" + ;; + "Neovide" | "MacVim" | "Vim" | "VimR") + icon_result=":vim:" + ;; + "Keynote" | "Keynote 讲演") + icon_result=":keynote:" + ;; + "iTerm") + icon_result=":iterm:" + ;; + "IntelliJ IDEA") + icon_result=":idea:" + ;; + "Finder" | "访达") + icon_result=":finder:" + ;; + "Xcode") + icon_result=":xcode:" + ;; + "GoLand") + icon_result=":goland:" + ;; + "Android Studio") + icon_result=":android_studio:" + ;; + "MoneyMoney") + icon_result=":bank:" + ;; + "Spotify") + icon_result=":spotify:" + ;; + "KeePassXC") + icon_result=":kee_pass_x_c:" + ;; + "Alfred") + icon_result=":alfred:" + ;; + "Color Picker" | "数码测色计") + icon_result=":color_picker:" + ;; + "Microsoft Word") + icon_result=":microsoft_word:" + ;; + "Microsoft PowerPoint") + icon_result=":microsoft_power_point:" + ;; + "Notes" | "备忘录") + icon_result=":notes:" + ;; + "Microsoft Edge") + icon_result=":microsoft_edge:" + ;; + "Sublime Text") + icon_result=":sublime_text:" + ;; + "Sequel Ace") + icon_result=":sequel_ace:" + ;; + "Folx") + icon_result=":folx:" + ;; + "DingTalk" | "钉钉" | "阿里钉") + icon_result=":dingtalk:" + ;; + "WebStorm") + icon_result=":web_storm:" + ;; + "Sequel Pro") + icon_result=":sequel_pro:" + ;; + "Skype") + icon_result=":skype:" + ;; + "网易云音乐") + icon_result=":netease_music:" + ;; + "PyCharm") + icon_result=":pycharm:" + ;; + "Canary Mail" | "HEY" | "Mail" | "Mailspring" | "MailMate" | "邮件") + icon_result=":mail:" + ;; + "Default") + icon_result=":default:" + ;; + "App Store") + icon_result=":app_store:" + ;; + "Calibre") + icon_result=":book:" + ;; + "Todoist") + icon_result=":todoist:" + ;; + "Emacs") + icon_result=":emacs:" + ;; + "Messenger") + icon_result=":messenger:" + ;; + "Tower") + icon_result=":tower:" + ;; + "VSCodium") + icon_result=":vscodium:" + ;; + "Drafts") + icon_result=":drafts:" + ;; + "Cypress") + icon_result=":cypress:" + ;; + "GitHub Desktop") + icon_result=":git_hub:" + ;; + "Telegram") + icon_result=":telegram:" + ;; + "Firefox Developer Edition" | "Firefox Nightly") + icon_result=":firefox_developer_edition:" + ;; + "Min") + icon_result=":min_browser:" + ;; + "Sketch") + icon_result=":sketch:" + ;; + "Affinity Photo") + icon_result=":affinity_photo:" + ;; + "MAMP" | "MAMP PRO") + icon_result=":mamp:" + ;; + "Insomnia") + icon_result=":insomnia:" + ;; + "Bitwarden") + icon_result=":bit_warden:" + ;; + "Warp") + icon_result=":warp:" + ;; + "System Preferences" | "System Settings" | "系统设置") + icon_result=":gear:" + ;; + "Affinity Designer") + icon_result=":affinity_designer:" + ;; + "Live") + icon_result=":ableton:" + ;; + "Arc") + icon_result=":arc:" + ;; + "Chromium" | "Google Chrome" | "Google Chrome Canary") + icon_result=":google_chrome:" + ;; + "Jellyfin Media Player") + icon_result=":jellyfin:" + ;; + "Zulip") + icon_result=":zulip:" + ;; + "1Password") + icon_result=":one_password:" + ;; + "FaceTime" | "FaceTime 通话") + icon_result=":face_time:" + ;; + "Citrix Workspace" | "Citrix Viewer") + icon_result=":citrix:" + ;; + "Logseq") + icon_result=":logseq:" + ;; + "Reeder") + icon_result=":reeder5:" + ;; + "Code" | "Code - Insiders") + icon_result=":code:" + ;; + "Notion") + icon_result=":notion:" + ;; + "Final Cut Pro") + icon_result=":final_cut_pro:" + ;; + "Zotero") + icon_result=":zotero:" + ;; + "Safari" | "Safari浏览器" | "Safari Technology Preview") + icon_result=":safari:" + ;; + "Blender") + icon_result=":blender:" + ;; + "Affinity Publisher") + icon_result=":affinity_publisher:" + ;; + "Spark Desktop") + icon_result=":spark:" + ;; + "Zeplin") + icon_result=":zeplin:" + ;; + "Replit") + icon_result=":replit:" + ;; + "Podcasts" | "播客") + icon_result=":podcasts:" + ;; + "NordVPN") + icon_result=":nord_vpn:" + ;; + "Notability") + icon_result=":notability:" + ;; + "Numbers" | "Numbers 表格") + icon_result=":numbers:" + ;; + "Nova") + icon_result=":nova:" + ;; + "Microsoft Excel") + icon_result=":microsoft_excel:" + ;; + "Trello") + icon_result=":trello:" + ;; + "Pi-hole Remote") + icon_result=":pihole:" + ;; + "Linear") + icon_result=":linear:" + ;; + "CleanMyMac X") + icon_result=":desktop:" + ;; + "GrandTotal" | "Receipts") + icon_result=":dollar:" + ;; + "Evernote Legacy") + icon_result=":evernote_legacy:" + ;; + "OmniFocus") + icon_result=":omni_focus:" + ;; + "Terminal" | "终端") + icon_result=":terminal:" + ;; + "Atom") + icon_result=":atom:" + ;; + "Kakoune") + icon_result=":kakoune:" + ;; + "Reminders" | "提醒事项") + icon_result=":reminders:" + ;; + "Tana") + icon_result=":tana:" + ;; + "OBS") + icon_result=":obsstudio:" + ;; + "VMware Fusion") + icon_result=":vmware_fusion:" + ;; + "Tweetbot" | "Twitter") + icon_result=":twitter:" + ;; + "Microsoft Teams") + icon_result=":microsoft_teams:" + ;; + "Yuque" | "语雀") + icon_result=":yuque:" + ;; + "Slack") + icon_result=":slack:" + ;; + "Vivaldi") + icon_result=":vivaldi:" + ;; + "Setapp") + icon_result=":setapp:" + ;; + "TIDAL") + icon_result=":tidal:" + ;; + "Miro") + icon_result=":miro:" + ;; + "Messages" | "信息" | "Nachrichten") + icon_result=":messages:" + ;; + "Brave Browser") + icon_result=":brave_browser:" + ;; + "Preview" | "预览" | "Skim" | "zathura") + icon_result=":pdf:" + ;; + "Obsidian") + icon_result=":obsidian:" + ;; + "Thunderbird") + icon_result=":thunderbird:" + ;; + "Firefox") + icon_result=":firefox:" + ;; + "WezTerm") + icon_result=":wezterm:" + ;; + *) + icon_result=":default:" + ;; + esac +} + +icon_map "$1" +echo "$icon_result" diff --git a/mac/.config/sketchybar.mon/plugins/kakaotalk.sh b/mac/.config/sketchybar.mon/plugins/kakaotalk.sh new file mode 100755 index 0000000..e959621 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/kakaotalk.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +TEXT=$(lsappinfo info -only StatusLabel "KakaoTalk" | grep -o '"label"="[0-9]*"' | awk -F'"' '{print $4}') + +if [[ $TEXT -gt 0 ]]; then + sketchybar -m --set $NAME drawing=on label="$TEXT" +else + sketchybar -m --set $NAME drawing=off +fi diff --git a/mac/.config/sketchybar.mon/plugins/keyboard.sh b/mac/.config/sketchybar.mon/plugins/keyboard.sh new file mode 100755 index 0000000..c6b5681 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/keyboard.sh @@ -0,0 +1,13 @@ +#!/bin/bash + +# this is jank and ugly, I know +LAYOUT="$(defaults read ~/Library/Preferences/com.apple.HIToolbox.plist AppleSelectedInputSources | grep "KeyboardLayout Name" | cut -c 33- | rev | cut -c 2- | rev)" + +# specify short layouts individually. +case "$LAYOUT" in +"\"Dvorak\"") SHORT_LAYOUT="DV" ;; +"\"U.S.\"") SHORT_LAYOUT="US" ;; +*) SHORT_LAYOUT="한" ;; +esac + +sketchybar --set keyboard label="$SHORT_LAYOUT" diff --git a/mac/.config/sketchybar.mon/plugins/mail.sh b/mac/.config/sketchybar.mon/plugins/mail.sh new file mode 100755 index 0000000..6a74b07 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/mail.sh @@ -0,0 +1,9 @@ +#!/usr/bin/env bash + +TEXT=$(lsappinfo info -only StatusLabel "Mail" | grep -o '"label"="[0-9]*"' | awk -F'"' '{print $4}') + +if [[ $TEXT -gt 0 ]]; then + sketchybar -m --set $NAME drawing=on label="$TEXT" +else + sketchybar -m --set $NAME drawing=off +fi
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/memory.sh b/mac/.config/sketchybar.mon/plugins/memory.sh new file mode 100755 index 0000000..6917458 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/memory.sh @@ -0,0 +1,49 @@ +#!/bin/bash + +source "$CONFIG_DIR/globalstyles.sh" + +# Get total physical memory in bytes +total_memory=$(sysctl -n hw.memsize) + +# Get memory page size in bytes +page_size=$(vm_stat | grep "page size of" | awk '{print $8}' | sed 's/\.$//') # Correctly strip the period at the end + +# Get various memory statistics from vm_stat +vm_stat=$(vm_stat) +pages_free=$(echo "$vm_stat" | grep "Pages free:" | awk '{print $3}' | sed 's/\.$//') # Remove dot at the end +pages_active=$(echo "$vm_stat" | grep "Pages active:" | awk '{print $3}' | sed 's/\.$//') +pages_inactive=$(echo "$vm_stat" | grep "Pages inactive:" | awk '{print $3}' | sed 's/\.$//') +pages_speculative=$(echo "$vm_stat" | grep "Pages speculative:" | awk '{print $3}' | sed 's/\.$//') +pages_wired_down=$(echo "$vm_stat" | grep "Pages wired down:" | awk '{print $4}' | sed 's/\.$//') +compressed_pages=$(echo "$vm_stat" | grep "Pages occupied by compressor:" | awk '{print $5}' | sed 's/\.$//') + +# Calculate total used memory pages +total_used_pages=$((pages_active + pages_wired_down + compressed_pages)) + +# Convert pages to bytes +total_used_memory_bytes=$((total_used_pages * page_size)) + +# Calculate memory used percentage as an integer +USAGE=$((total_used_memory_bytes * 100 / total_memory)) +COUNT="$(memory_pressure | grep "System-wide memory free percentage:" | awk '{ val = 100 - $5; if (val < 10) printf("%1.0f\n", val); else printf("%02.0f\n", val) }')" + +COLOR=$RED + +case "$COUNT" in +[5-6][0-9]) # 50-69% + COLOR=$YELLOW + ;; +[3-4][0-9]) # 20-49% + COLOR=$GREEN + ;; +[1-2][0-9]) # 10-19% + COLOR=$LAVENDER + ;; +[0-9]) # 0-9% + COLOR=$WHITE + ;; +esac + +sketchybar -m --set "$NAME" \ + label="$COUNT / $USAGE%" \ + icon.color=$COLOR diff --git a/mac/.config/sketchybar.mon/plugins/messages.sh b/mac/.config/sketchybar.mon/plugins/messages.sh new file mode 100755 index 0000000..1ca1ec1 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/messages.sh @@ -0,0 +1,7 @@ +TEXT=$(sqlite3 ~/Library/Messages/chat.db "SELECT text FROM message WHERE is_read=0 AND is_from_me=0 AND text!='' AND date_read=0" | wc -l | awk '{$1=$1};1') + +if [ $TEXT = 0 ]; then + sketchybar -m --set $NAME drawing=off +else + sketchybar -m --set $NAME drawing=on label="$TEXT" +fi
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/mic.sh b/mac/.config/sketchybar.mon/plugins/mic.sh new file mode 100755 index 0000000..35cde89 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/mic.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +MIC_VOLUME=$(osascript -e 'input volume of (get volume settings)') + +if [[ $MIC_VOLUME -eq 0 ]]; then + sketchybar -m --set mic icon= +elif [[ $MIC_VOLUME -gt 0 ]]; then + sketchybar -m --set mic icon= +fi diff --git a/mac/.config/sketchybar.mon/plugins/mic_click.sh b/mac/.config/sketchybar.mon/plugins/mic_click.sh new file mode 100755 index 0000000..90a6ac6 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/mic_click.sh @@ -0,0 +1,11 @@ +#!/bin/bash + +MIC_VOLUME=$(osascript -e 'input volume of (get volume settings)') + +if [[ $MIC_VOLUME -eq 0 ]]; then + osascript -e 'set volume input volume 25' + sketchybar -m --set mic icon= +elif [[ $MIC_VOLUME -gt 0 ]]; then + osascript -e 'set volume input volume 0' + sketchybar -m --set mic icon= +fi diff --git a/mac/.config/sketchybar.mon/plugins/music.sh b/mac/.config/sketchybar.mon/plugins/music.sh new file mode 100755 index 0000000..ce23701 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/music.sh @@ -0,0 +1,92 @@ +#!/bin/sh + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +music_item_defaults=( + align=center + width=240 + label.max_chars=33 +) + +music_cover=( + background.image=media.artwork + background.image.scale=5 + background.image.corner_radius=4 + background.image.padding_left=$PADDINGS + background.image.padding_right=$PADDINGS + background.label.align=center + y_offset=-$PADDINGS + align=center +) + +music_artist=( + "${music_item_defaults[@]}" +) + +music_title=( + "${music_item_defaults[@]}" + label.font.style="Bold" +) + +music_album=( + "${music_item_defaults[@]}" +) + +render_bar_item() { + sketchybar --set $NAME label="$CURRENT_ARTIST: $CURRENT_SONG" +} + +render_popup() { + sketchybar --set $NAME.cover "${music_cover[@]}" \ + --set $NAME.artist "${music_artist[@]}" \ + --set $NAME.title "${music_title[@]}" \ + --set $NAME.album "${music_album[@]}" +} + +update() { + CURRENT_ARTIST="$(echo "$INFO" | jq -r '.artist')" + CURRENT_SONG="$(echo "$INFO" | jq -r '.title')" + CURRENT_ALBUM="$(echo "$INFO" | jq -r '.album')" + PLAYER_STATE="$(echo "$INFO" | jq -r '.state')" + + if [ "$PLAYER_STATE" = "playing" ]; then + sketchybar --set $NAME drawing=on \ + icon= \ + --set $NAME.artist label="$CURRENT_ARTIST" \ + --set $NAME.title label="$CURRENT_SONG" \ + --set $NAME.album label="$CURRENT_ALBUM" + render_bar_item + render_popup + + else + sketchybar --set $NAME icon= + popup off + sketchybar --set $NAME drawing=off + fi + +} + +popup() { + sketchybar --set "$NAME" popup.drawing="$1" +} + +playpause() { + osascript -e 'tell application "Music" to playpause' +} + + +case "$SENDER" in +"routine" | "forced" | "media_change") + update + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +"mouse.clicked") + playpause + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/music/Cover-Default.png b/mac/.config/sketchybar.mon/plugins/music/Cover-Default.png Binary files differnew file mode 100644 index 0000000..a65c63f --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/music/Cover-Default.png diff --git a/mac/.config/sketchybar.mon/plugins/music/Get-Artwork.applescript b/mac/.config/sketchybar.mon/plugins/music/Get-Artwork.applescript new file mode 100644 index 0000000..ca3ee31 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/music/Get-Artwork.applescript @@ -0,0 +1,65 @@ +--get current path +tell application "Finder" to set current_path to container of (path to me) as alias + +--get artwork +tell application "Music" + try + if player state is not stopped then + set alb to (get album of current track) + tell artwork 1 of current track + if format is JPEG picture then + set imgFormat to ".jpg" + else + set imgFormat to ".png" + end if + end tell + set rawData to (get raw data of artwork 1 of current track) + else + return + end if + on error + return POSIX path of ((current_path as text) & "Cover-Default.png") + return + end try +end tell + +--create path to save image as jpg or png +set newPath to ((current_path as text) & "tmp" & imgFormat) as text + +try + --create file + tell me to set fileRef to (open for access newPath with write permission) + --overwrite existing file + write rawData to fileRef starting at 0 + tell me to close access fileRef + + delay 1 + + --resize image + set the target_length to 500 + try + tell application "Image Events" + -- start the Image Events application + launch + -- open the image file + set this_image to open newPath + -- perform action + scale this_image to size target_length + -- save the changes + save this_image with icon + -- purge the open image data + close this_image + end tell + on error + return POSIX path of ((current_path as text) & "Cover-Default.png") + end try + + return POSIX path of newPath +on error m number n + log n + log m + try + tell me to close access fileRef + end try + return ((current_path as text) & "Cover-Default.png") as text +end try
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/network.sh b/mac/.config/sketchybar.mon/plugins/network.sh new file mode 100755 index 0000000..99fda23 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/network.sh @@ -0,0 +1,25 @@ +#!/bin/bash + +source "$CONFIG_DIR/colors.sh" # Loads all defined colors +source "$CONFIG_DIR/icons.sh" # Loads all defined icons + +UPDOWN=$(ifstat -i "en0" -b 0.1 1 | tail -n1) +DOWN=$(echo "$UPDOWN" | awk "{ print \$1 }" | cut -f1 -d ".") +UP=$(echo "$UPDOWN" | awk "{ print \$2 }" | cut -f1 -d ".") + +DOWN_FORMAT="" +if [ "$DOWN" -gt "999" ]; then + DOWN_FORMAT=$(echo "$DOWN" | awk '{ printf "%03.0f Mbps", $1 / 1000}') +else + DOWN_FORMAT=$(echo "$DOWN" | awk '{ printf "%03.0f kbps", $1}') +fi + +UP_FORMAT="" +if [ "$UP" -gt "999" ]; then + UP_FORMAT=$(echo "$UP" | awk '{ printf "%03.0f Mbps", $1 / 1000}') +else + UP_FORMAT=$(echo "$UP" | awk '{ printf "%03.0f kbps", $1}') +fi + +sketchybar -m --set network.down label="$DOWN_FORMAT" icon.highlight=$(if [ "$DOWN" -gt "0" ]; then echo "on"; else echo "off"; fi) \ + --set network.up label="$UP_FORMAT" icon.highlight=$(if [ "$UP" -gt "0" ]; then echo "on"; else echo "off"; fi) diff --git a/mac/.config/sketchybar.mon/plugins/nextevent.applescript b/mac/.config/sketchybar.mon/plugins/nextevent.applescript new file mode 100755 index 0000000..6ffc56a --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/nextevent.applescript @@ -0,0 +1,19 @@ +set input to paragraphs of (do shell script "/opt/homebrew/bin/icalBuddy -ec 'Found in Natural Language,CCSF' -npn -nc -iep 'datetime,title' -po 'datetime,title' -eed -ea -n -li 4 -ps '|: |' -b '' eventsToday") + +set currentTime to date (do shell script "date '+%I:%M %p'") + +set theEvent to "" + +if input is not "" then + repeat with anEvent in input + set text item delimiters to "^" + set eventTime to date (text item 1 of anEvent) + set text item delimiters to "" + if eventTime > currentTime then + set theEvent to anEvent as string + exit repeat + end if + end repeat +end if + +return theEvent
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/nextevent.sh b/mac/.config/sketchybar.mon/plugins/nextevent.sh new file mode 100755 index 0000000..732629a --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/nextevent.sh @@ -0,0 +1,55 @@ +#!/usr/bin/env bash + +render_item() { + sketchybar --set $NAME label="$(date "+%I:%M %p")" +} + +render_popup() { + + if which "icalBuddy" &>/dev/null; then + input=$(/opt/homebrew/bin/icalBuddy -ec 'Found in Natural Language,CCSF' -npn -nc -iep 'datetime,title' -po 'datetime,title' -eed -ea -n -li 4 -ps '|: |' -b '' eventsToday) + currentTime=$(date '+%I:%M %p') + + # echo "Debug: $NAME #11 $input" + + if [ -n "$input" ]; then + IFS='^' read -ra events <<< "$input" + for anEvent in "${events[@]}"; do + IFS='^' read -ra eventItems <<< "$anEvent" + eventTime=${eventItems[0]} + if [ "$eventTime" '>' "$currentTime" ]; then + theEvent="$anEvent" + break + fi + done + else + theEvent="No events today" + fi + else + theEvent="Please install icalBuddy → brew install ical-buddy." + fi + + + sketchybar --set clock.details label="$theEvent" click_script="sketchybar --set $NAME popup.drawing=off" >/dev/null +} + +update() { + render_item +} + +popup() { + render_popup + sketchybar --set "$NAME" popup.drawing="$1" +} + +case "$SENDER" in +"routine" | "forced") + update + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +esac
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/space.py b/mac/.config/sketchybar.mon/plugins/space.py new file mode 100755 index 0000000..7ed3e55 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/space.py @@ -0,0 +1,199 @@ +#!/usr/bin/python3 + +import os, json, re + +ICON_MAP = [ + {"regex": r"1Password", "icon": ":one_password:"}, + {"regex": r"Affinity Designer", "icon": ":affinity_designer:"}, + {"regex": r"Affinity Photo", "icon": ":affinity_photo:"}, + {"regex": r"Affinity Publisher", "icon": ":affinity_publisher:"}, + {"regex": r"Airmail", "icon": ":airmail:"}, + {"regex": r"Alacritty|Hyper|iTerm2|kitty|Terminal|WezTerm", "icon": ":terminal:"}, + {"regex": r"Alfred", "icon": ":alfred:"}, + {"regex": r"Android Messages", "icon": ":android_messages:"}, + {"regex": r"Android Studio", "icon": ":android_studio:"}, + {"regex": r"App Store", "icon": ":app_store:"}, + {"regex": r"Atom", "icon": ":atom:"}, + {"regex": r"Audacity", "icon": ":audacity:"}, + {"regex": r"Bear", "icon": ":bear:"}, + {"regex": r"Bitwarden", "icon": ":bit_warden:"}, + {"regex": r"Blender", "icon": ":blender:"}, + {"regex": r"Brave Browser", "icon": ":brave_browser:"}, + {"regex": r"Calendar|Fantastical|Cron|Morgen", "icon": ":calendar:"}, + {"regex": r"Calibre", "icon": ":book:"}, + { + "regex": r"Canary Mail|HEY|Mail|Mailspring|MailMate|邮件|Outlook|Gmail|Mimestream", + "icon": ":mail:", + }, + {"regex": r"Caprine", "icon": ":caprine:"}, + { + "regex": r"Chromium|Google Chrome|Google Chrome Canary", + "icon": ":google_chrome:", + }, + {"regex": r"CleanMyMac X", "icon": ":desktop:"}, + {"regex": r"ClickUp", "icon": ":click_up:"}, + {"regex": r"Code|Code - Insiders", "icon": ":code:"}, + {"regex": r"Color Picker", "icon": ":color_picker:"}, + {"regex": r"DataGrip", "icon": ":datagrip:"}, + {"regex": r"Default", "icon": ":default:"}, + {"regex": r"DEVONthink 3", "icon": ":devonthink3:"}, + {"regex": r"Discord|Discord Canary|Discord PTB", "icon": ":discord:"}, + {"regex": r"Drafts", "icon": ":drafts:"}, + {"regex": r"Dropbox", "icon": ":dropbox:"}, + {"regex": r"Element", "icon": ":element:"}, + {"regex": r"Emacs", "icon": ":emacs:"}, + {"regex": r"Evernote Legacy", "icon": ":evernote_legacy:"}, + {"regex": r"FaceTime", "icon": ":face_time:"}, + {"regex": r"Figma", "icon": ":figma:"}, + {"regex": r"Final Cut Pro", "icon": ":final_cut_pro:"}, + {"regex": r"Finder|访达", "icon": ":finder:"}, + { + "regex": r"Firefox Developer Edition|Firefox Nightly", + "icon": ":firefox_developer_edition:", + }, + {"regex": r"Firefox", "icon": ":firefox:"}, + {"regex": r"Folx", "icon": ":folx:"}, + {"regex": r"GitHub Desktop", "icon": ":git_hub:"}, + {"regex": r"Grammarly Editor", "icon": ":grammarly:"}, + {"regex": r"GrandTotal|Receipts", "icon": ":dollar:"}, + {"regex": r"IINA", "icon": ":playing:"}, + {"regex": r"Insomnia", "icon": ":insomnia:"}, + {"regex": r"IntelliJ IDEA", "icon": ":idea:"}, + {"regex": r"Iris", "icon": ":iris:"}, + {"regex": r"Joplin", "icon": ":joplin:"}, + {"regex": r"Kakoune", "icon": ":kakoune:"}, + {"regex": r"KeePassXC", "icon": ":kee_pass_x_c:"}, + {"regex": r"Keyboard Maestro", "icon": ":keyboard_maestro:"}, + {"regex": r"Keynote", "icon": ":keynote:"}, + {"regex": r"League of Legends", "icon": ":league_of_legends:"}, + {"regex": r"LibreWolf", "icon": ":libre_wolf:"}, + {"regex": r"Linear", "icon": ":linear:"}, + {"regex": r"Live", "icon": ":ableton:"}, + {"regex": r"MAMP|MAMP PRO", "icon": ":mamp:"}, + {"regex": r"Matlab", "icon": ":matlab:"}, + {"regex": r"Mattermost", "icon": ":mattermost:"}, + {"regex": r"Messages|Nachrichten", "icon": ":messages:"}, + {"regex": r"Microsoft Edge", "icon": ":microsoft_edge:"}, + {"regex": r"Microsoft Excel", "icon": ":microsoft_excel:"}, + {"regex": r"Microsoft PowerPoint", "icon": ":microsoft_power_point:"}, + {"regex": r"Microsoft Teams", "icon": ":microsoft_teams:"}, + {"regex": r"Microsoft To Do|Things", "icon": ":things:"}, + {"regex": r"Microsoft Word", "icon": ":microsoft_word:"}, + {"regex": r"Min", "icon": ":min_browser:"}, + {"regex": r"MoneyMoney", "icon": ":bank:"}, + {"regex": r"mpv", "icon": ":mpv:"}, + {"regex": r"Music", "icon": ":music:"}, + {"regex": r"Neovide|MacVim|Vim|VimR", "icon": ":vim:"}, + {"regex": r"Notability", "icon": ":notability:"}, + {"regex": r"Notes", "icon": ":notes:"}, + {"regex": r"Notion", "icon": ":notion:"}, + {"regex": r"Nova", "icon": ":nova:"}, + {"regex": r"Numbers", "icon": ":numbers:"}, + {"regex": r"OBS", "icon": ":obsstudio:"}, + {"regex": r"Obsidian", "icon": ":obsidian:"}, + {"regex": r"OmniFocus", "icon": ":omni_focus:"}, + {"regex": r"Pages", "icon": ":pages:"}, + {"regex": r"Parallels Desktop", "icon": ":parallels:"}, + {"regex": r"Pi-hole Remote", "icon": ":pihole:"}, + {"regex": r"Pine", "icon": ":pine:"}, + {"regex": r"Podcasts", "icon": ":podcasts:"}, + {"regex": r"PomoDone App", "icon": ":pomodone:"}, + {"regex": r"Preview|Skim|zathura|PDFgear", "icon": ":pdf:"}, + {"regex": r"qutebrowser", "icon": ":qute_browser:"}, + {"regex": r"Reeder", "icon": ":reeder5:"}, + {"regex": r"Reminders", "icon": ":reminders:"}, + {"regex": r"Safari|Safari Technology Preview|Orion", "icon": ":safari:"}, + {"regex": r"Sequel Ace", "icon": ":sequel_ace:"}, + {"regex": r"Sequel Pro", "icon": ":sequel_pro:"}, + {"regex": r"Setapp", "icon": ":setapp:"}, + {"regex": r"Signal", "icon": ":signal:"}, + {"regex": r"Sketch", "icon": ":sketch:"}, + {"regex": r"Skype", "icon": ":skype:"}, + {"regex": r"Slack", "icon": ":slack:"}, + {"regex": r"Spark", "icon": ":spark:"}, + {"regex": r"Spotify", "icon": ":spotify:"}, + {"regex": r"Spotlight", "icon": ":spotlight:"}, + {"regex": r"Sublime Text", "icon": ":sublime_text:"}, + {"regex": r"System Preferences|System Settings", "icon": ":gear:"}, + {"regex": r"TeamSpeak 3", "icon": ":team_speak:"}, + {"regex": r"Telegram", "icon": ":telegram:"}, + {"regex": r"Thunderbird", "icon": ":thunderbird:"}, + {"regex": r"TickTick", "icon": ":tick_tick:"}, + {"regex": r"TIDAL", "icon": ":tidal:"}, + {"regex": r"Todoist", "icon": ":todoist:"}, + {"regex": r"Tor Browser", "icon": ":tor_browser:"}, + {"regex": r"Tower", "icon": ":tower:"}, + {"regex": r"Transmit", "icon": ":transmit:"}, + {"regex": r"Trello", "icon": ":trello:"}, + {"regex": r"Tweetbot|Twitter", "icon": ":twitter:"}, + {"regex": r"Typora", "icon": ":text:"}, + {"regex": r"Vivaldi", "icon": ":vivaldi:"}, + {"regex": r"VLC", "icon": ":vlc:"}, + {"regex": r"VMware Fusion", "icon": ":vmware_fusion:"}, + {"regex": r"VSCodium", "icon": ":vscodium:"}, + {"regex": r"WebStorm", "icon": ":web_storm:"}, + {"regex": r"WhatsApp", "icon": ":whats_app:"}, + {"regex": r"Xcode", "icon": ":xcode:"}, + {"regex": r"Zeplin", "icon": ":zeplin:"}, + {"regex": r"zoom.us", "icon": ":zoom:"}, + {"regex": r"Zotero", "icon": ":zotero:"}, + {"regex": r"Zulip", "icon": ":zulip:"}, + {"regex": r"微信", "icon": ":wechat:"}, + {"regex": r"网易云音乐", "icon": ":netease_music:"}, +] + + +def to_sup(s): + sups = { + "0": "\u2070", + "1": "\xb9", + "2": "\xb2", + "3": "\xb3", + "4": "\u2074", + "5": "\u2075", + "6": "\u2076", + "7": "\u2077", + "8": "\u2078", + "9": "\u2079", + } + + return "".join(sups.get(char, char) for char in str(s)) + + +def to_icon(app): + for x in ICON_MAP: + if re.search(x["regex"], app): + return x["icon"] + return ":default:" + + +def to_formatted_icon(app, c): + cnt = f" {to_sup(c)}" if c > 1 else "" + return f"{to_icon(app)}{cnt}" + + +def to_formatted_icons(apps): + return " ".join([to_formatted_icon(app, cnt) for app, cnt in apps.items()]) + + +spaces = {} +apps = json.loads(os.popen("yabai -m query --windows").read()) +for app in apps: + spaces[app["space"]] = spaces.get(app["space"], {}) + spaces[app["space"]][app["app"]] = spaces[app["space"]].get(app["app"], 0) + 1 + +args = " ".join( + [ + f'--set space.{space} label="{to_formatted_icons(apps)}" label.drawing=on' + for space, apps in spaces.items() + ] +) +default_args = "--set spaces_bracket drawing=off --set '/space\..*/' background.drawing=on --animate sin 10" + +args2 = "" +spaces = json.loads(os.popen("yabai -m query --spaces").read()) +for space in spaces: + if not space["windows"]: + args2 = f'{args2} --set space.{space["index"]} label="" label.drawing=off' + +os.system(f"sketchybar -m {default_args} {args} {args2}") diff --git a/mac/.config/sketchybar.mon/plugins/space.sh b/mac/.config/sketchybar.mon/plugins/space.sh new file mode 100755 index 0000000..70f3ac4 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/space.sh @@ -0,0 +1,62 @@ +#!/bin/bash + +source "$CONFIG_DIR/globalstyles.sh" + +if [ "$SELECTED" = "true" ]; then + COLOR=$HIGHLIGHT + OFFSET=-12 # under line + WIDTH="dynamic" +else + COLOR=$TRANSPARENT +fi + +sketchybar --animate tanh 10 \ + --set $NAME icon.highlight=$SELECTED \ + label.highlight=$SELECTED \ + background.color=$COLOR \ + background.y_offset=$OFFSET + +update() { + source "$CONFIG_DIR/colors.sh" + COLOR=$BACKGROUND_2 + WIDTH="dynamic" + + sketchybar --set $NAME icon.highlight=$SELECTED \ + label.highlight=$SELECTED \ + background.border_color=$COLOR \ + sketchybar --animate tanh 8 \ + label.width=$WIDTH \ +} + +set_space_label() { + sketchybar --set $NAME icon="$@" +} + +mouse_clicked() { + if [ "$BUTTON" = "right" ]; then + yabai -m space --destroy $SID + sketchybar --trigger space_change --trigger windows_on_spaces + else + if [ "$MODIFIER" = "shift" ]; then + SPACE_LABEL="$(osascript -e "return (text returned of (display dialog \"Give a name to space $NAME:\" default answer \"\" with icon note buttons {\"Cancel\", \"Continue\"} default button \"Continue\"))")" + if [ $? -eq 0 ]; then + if [ "$SPACE_LABEL" = "" ]; then + set_space_label "${NAME:6}" + else + set_space_label "${NAME:6} ($SPACE_LABEL)" + fi + fi + else + yabai -m space --focus $SID 2>/dev/null + fi + fi +} + +case "$SENDER" in +"mouse.clicked") + mouse_clicked + ;; +*) + update + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/space_windows.sh b/mac/.config/sketchybar.mon/plugins/space_windows.sh new file mode 100755 index 0000000..f175891 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/space_windows.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +if [ "$SENDER" = "space_windows_change" ]; then + args=(--animate sin 10) + + space="$(echo "$INFO" | jq -r '.space')" + apps="$(echo "$INFO" | jq -r '.apps | keys[]')" + + icon_strip=" " + if [ "${apps}" != "" ]; then + while read -r app; do + icon_strip+=" $($CONFIG_DIR/plugins/icon_map.sh "$app")" + done <<<"${apps}" + else + icon_strip="" + fi + args+=(--set space.$space label="$icon_strip") + + sketchybar -m "${args[@]}" +fi diff --git a/mac/.config/sketchybar.mon/plugins/spotify.sh b/mac/.config/sketchybar.mon/plugins/spotify.sh new file mode 100755 index 0000000..521ac60 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/spotify.sh @@ -0,0 +1,147 @@ +#!/bin/bash + +next () +{ + osascript -e 'tell application "Spotify" to play next track' +} + +back () +{ + osascript -e 'tell application "Spotify" to play previous track' +} + +play () +{ + osascript -e 'tell application "Spotify" to playpause' +} + +repeat () +{ + REPEAT=$(osascript -e 'tell application "Spotify" to get repeating') + if [ "$REPEAT" = "false" ]; then + sketchybar -m --set spotify.repeat icon.highlight=on + osascript -e 'tell application "Spotify" to set repeating to true' + else + sketchybar -m --set spotify.repeat icon.highlight=off + osascript -e 'tell application "Spotify" to set repeating to false' + fi +} + +shuffle () +{ + SHUFFLE=$(osascript -e 'tell application "Spotify" to get shuffling') + if [ "$SHUFFLE" = "false" ]; then + sketchybar -m --set spotify.shuffle icon.highlight=on + osascript -e 'tell application "Spotify" to set shuffling to true' + else + sketchybar -m --set spotify.shuffle icon.highlight=off + osascript -e 'tell application "Spotify" to set shuffling to false' + fi +} + +update () +{ + PLAYING=1 + if [ "$(echo "$INFO" | jq -r '.["Player State"]')" = "Playing" ]; then + PLAYING=0 + TRACK="$(echo "$INFO" | jq -r .Name)" + ARTIST="$(echo "$INFO" | jq -r .Artist)" + ALBUM="$(echo "$INFO" | jq -r .Album)" + SHUFFLE=$(osascript -e 'tell application "Spotify" to get shuffling') + REPEAT=$(osascript -e 'tell application "Spotify" to get repeating') + COVER=$(osascript -e 'tell application "Spotify" to get artwork url of current track') + fi + + args=() + if [ $PLAYING -eq 0 ]; then + curl -s --max-time 20 "$COVER" -o /tmp/cover.jpg + if [ "$ARTIST" == "" ]; then + args+=(--set spotify.title label="$TRACK" + --set spotify.album label="Podcast" + --set spotify.artist label="$ALBUM" ) + else + args+=(--set spotify.title label="$TRACK" + --set spotify.album label="$ALBUM" + --set spotify.artist label="$ARTIST") + fi + args+=(--set spotify.play icon= + --set spotify.shuffle icon.highlight=$SHUFFLE + --set spotify.repeat icon.highlight=$REPEAT + --set spotify.cover background.image="/tmp/cover.jpg" + background.color=0x00000000 + --set spotify.anchor drawing=on ) + else + args+=(--set spotify.anchor drawing=off popup.drawing=off + --set spotify.play icon= ) + fi + sketchybar -m "${args[@]}" +} + +scrubbing() { + DURATION_MS=$(osascript -e 'tell application "Spotify" to get duration of current track') + DURATION=$((DURATION_MS/1000)) + + TARGET=$((DURATION*PERCENTAGE/100)) + osascript -e "tell application \"Spotify\" to set player position to $TARGET" + sketchybar --set spotify.state slider.percentage=$PERCENTAGE +} + +scroll() { + DURATION_MS=$(osascript -e 'tell application "Spotify" to get duration of current track') + DURATION=$((DURATION_MS/1000)) + + FLOAT="$(osascript -e 'tell application "Spotify" to get player position')" + TIME=${FLOAT%.*} + + sketchybar --animate linear 10 \ + --set spotify.state slider.percentage="$((TIME*100/DURATION))" \ + icon="$(date -r $TIME +'%M:%S')" \ + label="$(date -r $DURATION +'%M:%S')" +} + +mouse_clicked () { + case "$NAME" in + "spotify.next") next + ;; + "spotify.back") back + ;; + "spotify.play") play + ;; + "spotify.shuffle") shuffle + ;; + "spotify.repeat") repeat + ;; + "spotify.state") scrubbing + ;; + *) exit + ;; + esac +} + +popup () { + sketchybar --set spotify.anchor popup.drawing=$1 +} + +routine() { + case "$NAME" in + "spotify.state") scroll + ;; + *) update + ;; + esac +} + +case "$SENDER" in + "mouse.clicked") mouse_clicked + ;; + "mouse.entered") popup on + ;; + "mouse.exited"|"mouse.exited.global") popup off + ;; + "routine") routine + ;; + "forced") exit 0 + ;; + *) update + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/svim.sh b/mac/.config/sketchybar.mon/plugins/svim.sh new file mode 100755 index 0000000..cb792b8 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/svim.sh @@ -0,0 +1,30 @@ +#!/bin/bash + +source "$CONFIG_DIR/icons.sh" +source "$CONFIG_DIR/colors.sh" + +if [ "$SENDER" = "svim_update" ]; then + DRAWING=on + DRAW_CMD=off + COLOR=$WHITE + case "$MODE" in + "I") ICON="$MODE_INSERT" DRAWING=off + ;; + "N") ICON="$MODE_NORMAL" + ;; + "V") ICON="$MODE_VISUAL" COLOR=$YELLOW + ;; + "C") ICON="$MODE_CMD" DRAW_CMD=on COLOR=$RED + ;; + "_") ICON="$MODE_PENDING" + ;; + *) DRAWING=off + ;; + esac + + sketchybar --set $NAME drawing="$DRAWING" \ + label.drawing="$DRAW_CMD" \ + icon="$ICON" \ + icon.color="$COLOR" \ + label="$CMDLINE" +fi diff --git a/mac/.config/sketchybar.mon/plugins/thunderbird.sh b/mac/.config/sketchybar.mon/plugins/thunderbird.sh new file mode 100755 index 0000000..53f8e31 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/thunderbird.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +TEXT=$(lsappinfo info -only StatusLabel "Thunderbird" | grep -o '"label"="[0-9]*"' | awk -F'"' '{print $4}') + +if [[ $TEXT -gt 0 ]]; then + sketchybar -m --set $NAME drawing=on label="$TEXT" +else + sketchybar -m --set $NAME drawing=off +fi diff --git a/mac/.config/sketchybar.mon/plugins/toggle_stats.sh b/mac/.config/sketchybar.mon/plugins/toggle_stats.sh new file mode 100755 index 0000000..b364c18 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/toggle_stats.sh @@ -0,0 +1,63 @@ +#!/bin/bash + +stats=( + cpu.top + cpu.percent + cpu.sys + cpu.user + memory + disk + network.up + network.down +) + +hide_stats() { + args=() + for item in "${stats[@]}"; do + args+=(--set "$item" drawing=off) + done + + sketchybar "${args[@]}" \ + --set separator_right \ + icon= \ + icon.font.size=25 \ + padding_right=10 +} + +show_stats() { + args=() + for item in "${stats[@]}"; do + args+=(--set "$item" drawing=on) + done + + sketchybar "${args[@]}" \ + --set separator_right \ + icon= \ + icon.font.size=25 \ + padding_right=10 +} + +toggle_stats() { + state=$(sketchybar --query separator_right | jq -r .icon.value) + + case $state in + "") + show_stats + ;; + "") + hide_stats + ;; + esac +} + +case "$SENDER" in +"hide_stats") + hide_stats + ;; +"show_stats") + show_stats + ;; +"toggle_stats") + toggle_stats + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/volume.sh b/mac/.config/sketchybar.mon/plugins/volume.sh new file mode 100755 index 0000000..a03a790 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/volume.sh @@ -0,0 +1,43 @@ +#!/bin/bash + +WIDTH=100 + +volume_change() { + source "$CONFIG_DIR/icons.sh" + source "$CONFIG_DIR/colors.sh" + + case $INFO in + [6-9][0-9]|100) ICON=$VOLUME_100 + ;; + [3-5][0-9]) ICON=$VOLUME_66 + ;; + [1-2][0-9]) ICON=$VOLUME_33 + ;; + [1-9]) ICON=$VOLUME_10 + ;; + 0) ICON=$VOLUME_0 + ;; + *) ICON=$VOLUME_100 + esac + + sketchybar --set volume_icon icon=$ICON + sketchybar --set $NAME slider.percentage=$INFO --animate tanh 30 --set $NAME slider.width=$WIDTH + sleep 2 + + # Check wether the volume was changed another time while sleeping + FINAL_PERCENTAGE=$(sketchybar --query $NAME | jq -r ".slider.percentage") + if [ "$FINAL_PERCENTAGE" -eq "$INFO" ]; then + sketchybar --animate tanh 30 --set $NAME slider.width=0 + fi +} + +mouse_clicked() { + osascript -e "set volume output volume $PERCENTAGE" +} + +case "$SENDER" in + "volume_change") volume_change + ;; + "mouse.clicked") mouse_clicked + ;; +esac
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/volume_click.sh b/mac/.config/sketchybar.mon/plugins/volume_click.sh new file mode 100755 index 0000000..e05c0d8 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/volume_click.sh @@ -0,0 +1,57 @@ +#!/bin/bash + +WIDTH=100 + +detail_on() { + sketchybar --animate tanh 30 --set volume slider.width=$WIDTH +} + +detail_off() { + sketchybar --animate tanh 30 --set volume slider.width=0 +} + +toggle_detail() { + INITIAL_WIDTH=$(sketchybar --query volume | jq -r ".slider.width") + if [ "$INITIAL_WIDTH" -eq "0" ]; then + detail_on + else + detail_off + fi +} + +toggle_devices() { + which SwitchAudioSource >/dev/null || exit 0 + source "$CONFIG_DIR/colors.sh" + source "$CONFIG_DIR/globalstyles.sh" + + args=(--remove '/volume.device\.*/' --set "$NAME" popup.drawing=toggle "${menu_defaults[@]}") + COUNTER=0 + CURRENT="$(SwitchAudioSource -t output -c)" + while IFS= read -r device; do + COLOR=$WHITE + ICON= + ICON_COLOR=$TRANSPARENT + if [ "${device}" = "$CURRENT" ]; then + COLOR=$HIGHLIGHT + ICON= + ICON_COLOR=$COLOR + fi + + args+=(--add item volume.device.$COUNTER popup."$NAME" \ + --set volume.device.$COUNTER label="${device}" \ + label.color="$COLOR" \ + icon=$ICON \ + icon.color=$ICON_COLOR \ + "${menu_item_defaults[@]}" \ + click_script="SwitchAudioSource -s \"${device}\" && sketchybar --set /volume.device\.*/ label.color=$GREY --set \$NAME label.color=$WHITE --set $NAME popup.drawing=off") + COUNTER=$((COUNTER+1)) + done <<< "$(SwitchAudioSource -a -t output)" + + sketchybar -m "${args[@]}" > /dev/null +} + +if [ "$BUTTON" = "left" ] || [ "$MODIFIER" = "shift" ]; then + toggle_devices +else + toggle_detail +fi
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/plugins/weather.sh b/mac/.config/sketchybar.mon/plugins/weather.sh new file mode 100755 index 0000000..61644de --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/weather.sh @@ -0,0 +1,191 @@ +#!/usr/bin/env bash + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +# API_KEY="462eeb49a1b844f191f175554222607" # insert api key here +API_KEY="2aa1a4f60e2542efae051005240402" # insert api key here + +# first comment is description, second is icon number +WEATHER_ICONS_DAY=( + [1000]= # Sunny/113 + [1003]= # Partly cloudy/116 + [1006]= # Cloudy/119 + [1009]= # Overcast/122 + [1030]= # Mist/143 + [1063]= # Patchy rain possible/176 + [1066]= # Patchy snow possible/179 + [1069]= # Patchy sleet possible/182 + [1072]= # Patchy freezing drizzle possible/185 + [1087]= # Thundery outbreaks possible/200 + [1114]= # Blowing snow/227 + [1117]= # Blizzard/230 + [1135]= # Fog/248 + [1147]= # Freezing fog/260 + [1150]= # Patchy light drizzle/263 + [1153]= # Light drizzle/266 + [1168]= # Freezing drizzle/281 + [1171]= # Heavy freezing drizzle/284 + [1180]= # Patchy light rain/293 + [1183]= # Light rain/296 + [1186]= # Moderate rain at times/299 + [1189]= # Moderate rain/302 + [1192]= # Heavy rain at times/305 + [1195]= # Heavy rain/308 + [1198]= # Light freezing rain/311 + [1201]= # Moderate or heavy freezing rain/314 + [1204]= # Light sleet/317 + [1207]= # Moderate or heavy sleet/320 + [1210]= # Patchy light snow/323 + [1213]= # Light snow/326 + [1216]= # Patchy moderate snow/329 + [1219]= # Moderate snow/332 + [1222]= # Patchy heavy snow/335 + [1225]= # Heavy snow/338 + [1237]= # Ice pellets/350 + [1240]= # Light rain shower/353 + [1243]= # Moderate or heavy rain shower/356 + [1246]= # Torrential rain shower/359 + [1249]= # Light sleet showers/362 + [1252]= # Moderate or heavy sleet showers/365 + [1255]= # Light snow showers/368 + [1258]= # Moderate or heavy snow showers/371 + [1261]= # Light showers of ice pellets/374 + [1264]= # Moderate or heavy showers of ice pellets/377 + [1273]= # Patchy light rain with thunder/386 + [1276]= # Moderate or heavy rain with thunder/389 + [1279]= # Patchy light snow with thunder/392 + [1282]= # Moderate or heavy snow with thunder/395 +) + +WEATHER_ICONS_NIGHT=( + [1000]= # Clear/113 + [1003]= # Partly cloudy/116 + [1006]= # Cloudy/119 + [1009]= # Overcast/122 + [1030]= # Mist/143 + [1063]= # Patchy rain possible/176 + [1066]= # Patchy snow possible/179 + [1069]= # Patchy sleet possible/182 + [1072]= # Patchy freezing drizzle possible/185 + [1087]= # Thundery outbreaks possible/200 + [1114]= # Blowing snow/227 + [1117]= # Blizzard/230 + [1135]= # Fog/248 + [1147]= # Freezing fog/260 + [1150]= # Patchy light drizzle/263 + [1153]= # Light drizzle/266 + [1168]= # Freezing drizzle/281 + [1171]= # Heavy freezing drizzle/284 + [1180]= # Patchy light rain/293 + [1183]= # Light rain/296 + [1186]= # Moderate rain at times/299 + [1189]= # Moderate rain/302 + [1192]= # Heavy rain at times/305 + [1195]= # Heavy rain/308 + [1198]= # Light freezing rain/311 + [1201]= # Moderate or heavy freezing rain/314 + [1204]= # Light sleet/317 + [1207]= # Moderate or heavy sleet/320 + [1210]= # Patchy light snow/323 + [1213]= # Light snow/326 + [1216]= # Patchy moderate snow/329 + [1219]= # Moderate snow/332 + [1222]= # Patchy heavy snow/335 + [1225]= # Heavy snow/338 + [1237]= # Ice pellets/350 + [1240]= # Light rain shower/353 + [1243]= # Moderate or heavy rain shower/356 + [1246]= # Torrential rain shower/359 + [1249]= # Light sleet showers/362 + [1252]= # Moderate or heavy sleet showers/365 + [1255]= # Light snow showers/368 + [1258]= # Moderate or heavy snow showers/371 + [1261]= # Light showers of ice pellets/374 + [1264]= # Moderate or heavy showers of ice pellets/377 + [1273]= # Patchy light rain with thunder/386 + [1276]= # Moderate or heavy rain with thunder/389 + [1279]= # Patchy light snow with thunder/392 + [1282]= # Moderate or heavy snow with thunder/395 +) + +render_item() { + if [ "$CITY" = "" ]; then + args+=(--set $NAME icon="" label.drawing=off icon.padding_right=-3) + else + args+=(--set $NAME icon="$ICON" icon.font="Hack Nerd Font:Bold:14.0" label="${TEMP}°C" label.drawing=on icon.padding_right=-3) + fi + + sketchybar "${args[@]}" >/dev/null + +} + +render_popup() { + if [ "$CITY" = "" ]; then + args+=(--set weather.details label="N/A" + click_script="sketchybar --set $NAME popup.drawing=off") + else + args+=(--set weather.details label="$CONDITION_TEXT, Humidity: $HUMIDITY% ($LOCATION)" + click_script="sketchybar --set $NAME popup.drawing=off") + fi + + sketchybar "${args[@]}" >/dev/null + +} + +update() { + CURRENT_WIFI="$(/System/Library/PrivateFrameworks/Apple80211.framework/Versions/Current/Resources/airport -I)" + SSID="$(echo "$CURRENT_WIFI" | grep -o "SSID: .*" | sed 's/^SSID: //')" + + # Attempt to get the city name using the IP info service + CITY="$(curl -s -m 5 ipinfo.io/loc)" + + # Check if the CITY variable is empty or contains an error message + if [ -z "$CITY" ] || echo "$CITY" | grep -q "error"; then + # Default to Birmingham,AL if the curl command failed or returned an error + CITY="Birmingham,AL" + fi + + # Replace spaces with '%20' for URL encoding + CITY=$(echo "$CITY" | sed 's/ /%20/g') + + if [ "$CITY" != "" ]; then + DATA=$(curl -s -m 5 "http://api.weatherapi.com/v1/current.json?key=$API_KEY&q=$CITY") + CONDITION=$(echo $DATA | jq -r '.current.condition.code') + CONDITION_TEXT=$(echo $DATA | jq -r '.current.condition.text') + TEMP=$(echo $DATA | jq -r '.current.temp_c | floor') + FEELSLIKE=$(echo $DATA | jq -r '.current.feelslike_f') + HUMIDITY=$(echo $DATA | jq -r '.current.humidity') + IS_DAY=$(echo $DATA | jq -r '.current.is_day') + LOCATION=$(echo $DATA | jq -r '.location.name' && echo ', ' && echo $DATA | jq -r '.location.country') + + [ "$IS_DAY" = "1" ] && ICON=${WEATHER_ICONS_DAY[$CONDITION]} || ICON=${WEATHER_ICONS_NIGHT[$CONDITION]} + args=() + fi + + render_item + render_popup + + if [ "$SENDER" = "forced" ]; then + sketchybar --set "$NAME" + fi +} + +popup() { + sketchybar --set "$NAME" popup.drawing="$1" +} + +case "$SENDER" in +"routine" | "forced" | "wifi_change") + update + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +"mouse.clicked") + popup toggle + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/wifi.sh b/mac/.config/sketchybar.mon/plugins/wifi.sh new file mode 100755 index 0000000..3f78223 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/wifi.sh @@ -0,0 +1,104 @@ +#!/bin/bash + +POPUP_OFF="sketchybar --set wifi popup.drawing=off" +POPUP_CLICK_SCRIPT="sketchybar --set wifi popup.drawing=toggle" + +source "$CONFIG_DIR/globalstyles.sh" # Loads defined colors + +INFO="$(/System/Library/PrivateFrameworks/Apple80211.framework/Resources/airport -I | awk -F ' SSID: ' '/ SSID: / {print $2}')" +IS_VPN=$(/usr/local/bin/piactl get connectionstate) +CURRENT_WIFI="$(/System/Library/PrivateFrameworks/Apple80211.framework/Versions/Current/Resources/airport -I)" +IP_ADDRESS="$(ipconfig getifaddr en0)" +SSID="$(echo "$CURRENT_WIFI" | grep -o "SSID: .*" | sed 's/^SSID: //')" +CURR_TX="$(echo "$CURRENT_WIFI" | grep -o "lastTxRate: .*" | sed 's/^lastTxRate: //')" + +# ICON="$([ -n "$INFO" ] && echo "$WIFI_CONNECTED" || echo "$WIFI_DISCONNECTED")" + +if [ -n "$INFO" ]; then + ICON_COLOR=$GREEN + ICON="$WIFI_CONNECTED" +elif [ -z "$INFO" ]; then + ICON="$WIFI_DISCONNECTED" +elif [[ $IS_VPN != "Disconnected" ]]; then + ICON_COLOR=$HIGHLIGHT + ICON= +elif [[ $SSID = "Ebrietas" ]]; then + ICON_COLOR=$WHITE + ICON= +elif [[ $SSID != "" ]]; then + ICON_COLOR=$WHITE + ICON= +elif [[ $CURRENT_WIFI = "AirPort: Off" ]]; then + ICON_COLOR=$RED + ICON= +else + ICON_COLOR=$WHITE_25 + ICON= +fi + +render_bar_item() { + sketchybar --set $NAME \ + icon.color=$ICON_COLOR \ + icon=$ICON \ + click_script="$POPUP_CLICK_SCRIPT" +} + +render_popup() { + if [ "$SSID" != "" ]; then + args=( + --set wifi click_script="$POPUP_CLICK_SCRIPT" + --set wifi.ssid label="$SSID" + --set wifi.strength label="$CURR_TX Mbps" + --set wifi.ipaddress label="$IP_ADDRESS" + click_script="printf $IP_ADDRESS | pbcopy;$POPUP_OFF" + ) + else + args=( + --set wifi click_script="") + fi + + sketchybar "${args[@]}" >/dev/null +} + +update() { + render_bar_item + render_popup + source "$CONFIG_DIR/icons.sh" + INFO="$(/System/Library/PrivateFrameworks/Apple80211.framework/Resources/airport -I | awk -F ' SSID: ' '/ SSID: / {print $2}')" + LABEL="$INFO ($(ipconfig getifaddr en0))" + ICON="$([ -n "$INFO" ] && echo "$WIFI_CONNECTED" || echo "$WIFI_DISCONNECTED")" + sketchybar --set $NAME icon="$ICON" label="$LABEL" +} + +click() { + CURRENT_WIDTH="$(sketchybar --query $NAME | jq -r .label.width)" + + WIDTH=0 + if [ "$CURRENT_WIDTH" -eq "0" ]; then + WIDTH=dynamic + fi + + sketchybar --animate sin 20 --set $NAME label.width="$WIDTH" +} + +popup() { + sketchybar --set "$NAME" popup.drawing="$1" +} + +case "$SENDER" in +"routine" | "forced") + update + ;; +"mouse.entered") + popup on + ;; +"mouse.exited" | "mouse.exited.global") + popup off + ;; +"wifi_change") + update + ;; +"mouse.clicked") + click + ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/yabai.sh b/mac/.config/sketchybar.mon/plugins/yabai.sh new file mode 100755 index 0000000..6027de1 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/yabai.sh @@ -0,0 +1,141 @@ +#!/bin/bash + +# window_state() { +# source "$CONFIG_DIR/globalstyles.sh" +# +# COLOR=$LABEL_COLOR +# +# WINDOW=$(yabai -m query --windows --window) +# read -r FLOATING SPLIT PARENT FULLSCREEN STICKY STACK_INDEX <<<$(echo "$WINDOW" | jq -rc '.["is-floating", "split-type", "has-parent-zoom", "has-fullscreen-zoom", "is-sticky", "stack-index"]') +# +# if [[ $STACK_INDEX -gt 0 ]]; then +# LAST_STACK_INDEX=$(yabai -m query --windows --window stack.last | jq '.["stack-index"]') +# ICON=$YABAI_STACK +# LABEL="$(printf "%s/%s " "$STACK_INDEX" "$LAST_STACK_INDEX")" +# COLOR=$YELLOW +# elif [[ $FLOATING == "true" ]]; then +# ICON=$YABAI_FLOAT +# elif [[ $PARENT == "true" ]]; then +# ICON="" +# elif [[ $FULLSCREEN == "true" ]]; then +# ICON=$YABAI_FULLSCREEN_ZOOM +# elif [[ $SPLIT == "vertical" ]]; then +# ICON=$YABAI_SPLIT_VERTICAL +# elif [[ $SPLIT == "horizontal" ]]; then +# ICON=$YABAI_SPLIT_HORIZONTAL +# else +# ICON=$YABAI_GRID +# fi +# +# args=(--bar border_color=$COLOR --animate sin 10 --set $NAME icon=$ICON icon.color=$COLOR) +# +# [ -z "$LABEL" ] && args+=(label.drawing=off) || +# args+=(label.drawing=on label="$LABEL" label.color=$COLOR) +# +# [ -z "$ICON" ] && args+=(icon.width=0) || +# args+=(icon="$ICON") +# +# sketchybar -m "${args[@]}" +# } +# +# windows_on_spaces() { +# /usr/bin/python3 $CONFIG_DIR/plugins/space.py # New spaces python script to consolidate spaces +# } +# +# mouse_clicked() { +# +# yabai_mode=$(yabai -m query --spaces --space | jq -r .type) +# +# case "$yabai_mode" in +# bsp) +# yabai -m config layout stack +# ;; +# stack) +# yabai -m config layout float +# ;; +# float) +# yabai -m config layout bsp +# ;; +# esac +# +# window_state +# } +# +# case "$SENDER" in +# "mouse.clicked") +# mouse_clicked +# ;; +# "forced") +# exit 0 +# ;; +# "window_focus") +# window_state +# ;; +# "windows_on_spaces" | "space_change") +# windows_on_spaces +# ;; +# esac + +window_state() { + source "$CONFIG_DIR/colors.sh" + source "$CONFIG_DIR/icons.sh" + + COLOR=$ROSEWATER + + WINDOW=$(yabai -m query --windows --window) + read -r FLOATING SPLIT PARENT FULLSCREEN STICKY STACK_INDEX <<<$(echo "$WINDOW" | jq -rc '.["is-floating", "split-type", "has-parent-zoom", "has-fullscreen-zoom", "is-sticky", "stack-index"]') + + if [[ $STACK_INDEX -gt 0 ]]; then + LAST_STACK_INDEX=$(yabai -m query --windows --window stack.last | jq '.["stack-index"]') + ICON=$YABAI_STACK + LABEL="$(printf "%s/%s " "$STACK_INDEX" "$LAST_STACK_INDEX")" + COLOR=$YELLOW + elif [[ $FLOATING == "true" ]]; then + ICON=$YABAI_FLOAT + elif [[ $PARENT == "true" ]]; then + ICON="" + elif [[ $FULLSCREEN == "true" ]]; then + ICON=$YABAI_FULLSCREEN_ZOOM + elif [[ $SPLIT == "vertical" ]]; then + ICON=$YABAI_SPLIT_VERTICAL + elif [[ $SPLIT == "horizontal" ]]; then + ICON=$YABAI_SPLIT_HORIZONTAL + else + ICON=$YABAI_GRID + fi + + args=(--bar --animate sin 10 --set $NAME icon=$ICON icon.color=$COLOR) + # args=(--bar border_color=$COLOR --animate sin 10 --set $NAME icon=$ICON icon.color=$COLOR) + + [ -z "$LABEL" ] && args+=(label.drawing=off) || + args+=(label.drawing=on label="$LABEL" label.color=$COLOR) + + [ -z "$ICON" ] && args+=(icon.width=0) || + args+=(icon="$ICON") + + sketchybar -m "${args[@]}" +} + +windows_on_spaces() { + /usr/bin/python3 $CONFIG_DIR/plugins/space.py # New spaces python script to consolidate spaces +} + +mouse_clicked() { + yabai -m window --toggle float + window_state +} + +case "$SENDER" in +"mouse.clicked") + mouse_clicked + ;; +"forced") + exit 0 + ;; +"window_focus") + window_state + ;; +# "windows_on_spaces" | "space_change") +# windows_on_spaces +# ;; +esac diff --git a/mac/.config/sketchybar.mon/plugins/zen.sh b/mac/.config/sketchybar.mon/plugins/zen.sh new file mode 100755 index 0000000..38f2291 --- /dev/null +++ b/mac/.config/sketchybar.mon/plugins/zen.sh @@ -0,0 +1,43 @@ +#!/bin/bash + +zen_on() { + sketchybar --set wifi drawing=off \ + --set apple.logo drawing=off \ + --set '/cpu.*/' drawing=off \ + --set calendar icon.drawing=off \ + --set separator drawing=off \ + --set front_app drawing=off \ + --set volume_icon drawing=off \ + --set spotify.anchor drawing=off \ + --set spotify.play updates=off \ + --set brew drawing=off \ + --set volume drawing=off \ + --set github.bell drawing=off +} + +zen_off() { + sketchybar --set wifi drawing=on \ + --set apple.logo drawing=on \ + --set '/cpu.*/' drawing=on \ + --set calendar icon.drawing=on \ + --set separator drawing=on \ + --set front_app drawing=on \ + --set volume_icon drawing=on \ + --set spotify.play updates=on \ + --set brew drawing=on \ + --set volume drawing=on \ + --set github.bell drawing=on +} + +if [ "$1" = "on" ]; then + zen_on +elif [ "$1" = "off" ]; then + zen_off +else + if [ "$(sketchybar --query apple.logo | jq -r ".geometry.drawing")" = "on" ]; then + zen_on + else + zen_off + fi +fi + diff --git a/mac/.config/sketchybar.mon/sketchybar/ 👽 aerospace-config/.aerospace.toml b/mac/.config/sketchybar.mon/sketchybar/ 👽 aerospace-config/.aerospace.toml new file mode 100644 index 0000000..e42aef7 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/ 👽 aerospace-config/.aerospace.toml @@ -0,0 +1,256 @@ + +# It's not neceesary to copy all keys to your config. +# If the key is missing in your config, "default-config.toml" will serve as a fallback + +# You can use it to add commands that run after login to macOS user session. +# 'start-at-login' needs to be 'true' for 'after-login-command' to work +# Available commands: https://nikitabobko.github.io/AeroSpace/commands +after-login-command = [] + +# You can use it to add commands that run after AeroSpace startup. +# 'after-startup-command' is run after 'after-login-command' +# Available commands : https://nikitabobko.github.io/AeroSpace/commands +after-startup-command = [ + # JankyBorders has a built-in detection of already running process, + # so it won't be run twice on AeroSpace restart + 'exec-and-forget /opt/homebrew/opt/sketchybar/bin/sketchybar', + # 'exec-and-forget /opt/homebrew/opt/borders/bin/borders active_color="glow(0xd943ff64)" inactive_color=0x20494d64 width=8.0' +] + +exec-on-workspace-change = [ + '/bin/bash', + '-c', + '/opt/homebrew/opt/sketchybar/bin/sketchybar --trigger aerospace_workspace_change AEROSPACE_FOCUSED_WORKSPACE=$AEROSPACE_FOCUSED_WORKSPACE AEROSPACE_PREV_WORKSPACE=$AEROSPACE_PREV_WORKSPACE', +] + +# Start AeroSpace at login +start-at-login = true + +# Normalizations. See: https://nikitabobko.github.io/AeroSpace/guide#normalization +enable-normalization-flatten-containers = false +enable-normalization-opposite-orientation-for-nested-containers = false + +# See: https://nikitabobko.github.io/AeroSpace/guide#layouts +# The 'accordion-padding' specifies the size of accordion padding +# You can set 0 to disable the padding feature +accordion-padding = 20 + +# Possible values: tiles|accordion +default-root-container-layout = 'tiles' + +# Possible values: horizontal|vertical|auto +# 'auto' means: wide monitor (anything wider than high) gets horizontal orientation, +# tall monitor (anything higher than wide) gets vertical orientation +default-root-container-orientation = 'auto' + +# Possible values: (qwerty|dvorak) +# See https://nikitabobko.github.io/AeroSpace/guide#key-mapping +key-mapping.preset = 'qwerty' + +# CURSOR CENTERING DISABLED - Keep cursor position when switching workspaces +# on-focused-monitor-changed = ['move-mouse monitor-lazy-center'] +# on-focus-changed = ['move-mouse window-lazy-center'] + +# Gaps between windows (inner-*) and between monitor edges (outer-*). +# Possible values: +# - Constant: gaps.outer.top = 8 +# - Per monitor: gaps.outer.top = [{ monitor.main = 16 }, { monitor."some-pattern" = 32 }, 24] +# In this example, 24 is a default value when there is no match. +# Monitor pattern is the same as for 'workspace-to-monitor-force-assignment'. +# See: https://nikitabobko.github.io/AeroSpace/guide#assign-workspaces-to-monitors + +[gaps] +inner.horizontal = 10 +inner.vertical = 10 +outer.top = [{ monitor."main" = 5 }, {monitor."secondary" = 40}, 5] +outer.left = 10 +outer.bottom = 10 +outer.right = 10 + +# See https://nikitabobko.github.io/AeroSpace/guide#exec-env-vars +[exec] # Again, you don't need to copy all config sections to your config. +inherit-env-vars = true # If you don't touch "exec" section, + +[exec.env-vars] # it will fallback to "default-config.toml" +PATH = '/opt/homebrew/bin:/opt/homebrew/sbin:${PATH}' + +# 'main' binding mode declaration +# See: https://nikitabobko.github.io/AeroSpace/guide#binding-modes +# 'main' binding mode must be always presented +[mode.main.binding] + +# All possible keys: +# - Letters. a, b, c, ..., z +# - Numbers. 0, 1, 2, ..., 9 +# - Keypad numbers. keypad0, keypad1, keypad2, ..., keypad9 +# - F-keys. f1, f2, ..., f20 +# - Special keys. minus, equal, period, comma, slash, backslash, quote, semicolon, backtick, +# leftSquareBracket, rightSquareBracket, space, enter, esc, backspace, tab +# - Keypad special. keypadClear, keypadDecimalMark, keypadDivide, keypadEnter, keypadEqual, +# keypadMinus, keypadMultiply, keypadPlus +# - Arrows. left, down, up, right + +# All possible modifiers: cmd, alt, ctrl, shift + +# All possible commands: https://nikitabobko.github.io/AeroSpace/commands + +# You can uncomment this line to open up terminal with alt + enter shortcut +# See: https://nikitabobko.github.io/AeroSpace/commands#exec-and-forget +# alt-enter = 'exec-and-forget open -n /System/Applications/Utilities/Terminal.app' + +# See: https://nikitabobko.github.io/AeroSpace/commands#layout +alt-slash = 'layout tiles horizontal vertical' +alt-comma = 'layout accordion horizontal vertical' + +# See: https://nikitabobko.github.io/AeroSpace/commands#focus +alt-h = 'focus left --boundaries all-monitors-outer-frame' +alt-j = 'focus down --boundaries all-monitors-outer-frame' +alt-k = 'focus up --boundaries all-monitors-outer-frame' +alt-l = 'focus right --boundaries all-monitors-outer-frame' + +# See: https://nikitabobko.github.io/AeroSpace/commands#move +alt-shift-h = 'move left' +alt-shift-j = 'move down' +alt-shift-k = 'move up' +alt-shift-l = 'move right' + +# See: https://nikitabobko.github.io/AeroSpace/commands#resize +alt-shift-minus = 'resize smart -50' +alt-shift-equal = 'resize smart +50' + +# See: https://nikitabobko.github.io/AeroSpace/commands#workspace +alt-1 = 'workspace 1' +alt-2 = 'workspace 2' +alt-3 = 'workspace 3' +alt-4 = 'workspace 4' +alt-5 = 'workspace 5' +alt-6 = 'workspace 6' +alt-7 = 'workspace 7' +alt-8 = 'workspace 8' +alt-9 = 'workspace 9' +alt-0 = 'workspace 10' +alt-t = 'workspace t' + +# See: https://nikitabobko.github.io/AeroSpace/commands#move-node-to-workspace +alt-shift-1 = ['move-node-to-workspace 1', 'workspace 1'] +alt-shift-2 = ['move-node-to-workspace 2', 'workspace 2'] +alt-shift-3 = ['move-node-to-workspace 3', 'workspace 3'] +alt-shift-4 = ['move-node-to-workspace 4', 'workspace 4'] +alt-shift-5 = ['move-node-to-workspace 5', 'workspace 5'] +alt-shift-6 = ['move-node-to-workspace 6', 'workspace 6'] +alt-shift-7 = ['move-node-to-workspace 7', 'workspace 7'] +alt-shift-8 = ['move-node-to-workspace 8', 'workspace 8'] +alt-shift-9 = ['move-node-to-workspace 9', 'workspace 9'] +alt-shift-0 = ['move-node-to-workspace 10', 'workspace 10'] +alt-shift-t = ['move-node-to-workspace t', 'workspace t'] +# See: https://nikitabobko.github.io/AeroSpace/commands#workspace-back-and-forth +alt-tab = 'workspace-back-and-forth' +# See: https://nikitabobko.github.io/AeroSpace/commands#move-workspace-to-monitor +alt-shift-tab = 'move-workspace-to-monitor --wrap-around next' + +# See: https://nikitabobko.github.io/AeroSpace/commands#mode +alt-shift-semicolon = 'mode service' + +# 'service' binding mode declaration. +# See: https://nikitabobko.github.io/AeroSpace/guide#binding-modes + +# disabled hide window +# cmd-h = [] +# rotate hangul and english + +alt-shift-f = 'fullscreen' + +[mode.service.binding] +esc = ['reload-config', 'mode main'] +r = ['flatten-workspace-tree', 'mode main'] # reset layout +#s = ['layout sticky tiling', 'mode main'] # sticky is not yet supported https://github.com/nikitabobko/AeroSpace/issues/2 +f = [ + 'layout floating tiling', + 'mode main', +] # Toggle between floating and tiling layout +alt-shift-semicolon = [ + 'fullscreen', + 'mode main', +] # Toggle between floating and tiling layout +backspace = ['close-all-windows-but-current', 'mode main'] + +alt-shift-h = ['join-with left', 'mode main'] +alt-shift-j = ['join-with down', 'mode main'] +alt-shift-k = ['join-with up', 'mode main'] +alt-shift-l = ['join-with right', 'mode main'] + +alt-shift-r = ['exec-and-forget /opt/homebrew/bin/sketchybar --reload'] + + + +# Custom window movement configuration +# ScreenStudio - set to floating to prevent window management issues +[[on-window-detected]] +if.app-id = 'com.timpler.screenstudio' +run = ['layout floating'] + +# 1. Cursor +[[on-window-detected]] +if.app-id = 'com.todesktop.230313mzl4w4u92' +run = ['move-node-to-workspace 1'] + +# 2. Chrome +[[on-window-detected]] +if.app-id = 'com.google.Chrome' +run = ['move-node-to-workspace 2'] + +# 3. Warp - split with GitHub Desktop +[[on-window-detected]] +if.app-id = 'dev.warp.Warp-Stable' +run = ['move-node-to-workspace 3'] + +# 3. GitHub Desktop - split with Warp +[[on-window-detected]] +if.app-id = 'com.github.GitHubClient' +run = ['move-node-to-workspace 3'] + +# 4. Slack +[[on-window-detected]] +if.app-id = 'com.tinyspeck.slackmacgap' +run = ['move-node-to-workspace 4'] + +# 5. ChatGPT +[[on-window-detected]] +if.app-id = 'com.openai.chat' +run = ['move-node-to-workspace 5'] + +# 6. WhatsApp +[[on-window-detected]] +if.app-id = 'net.whatsapp.WhatsApp' +run = ['move-node-to-workspace 6'] + +# 7. Finder +[[on-window-detected]] +if.app-id = 'com.apple.finder' +run = ['move-node-to-workspace 7'] + +# 8. Calendar (macOS native Calendar app) +[[on-window-detected]] +if.app-id = 'com.apple.iCal' +run = ['move-node-to-workspace 8'] + + +# Pritunl - always floating in same active window +[[on-window-detected]] +if.app-id = 'com.electron.pritunl' +run = ['layout floating'] + +# System Preferences - always floating +[[on-window-detected]] +if.app-id = 'com.apple.systempreferences' +run = ['layout floating'] + +# System Settings (macOS Ventura+) - always floating +[[on-window-detected]] +if.app-id = 'com.apple.SystemPreferences' +run = ['layout floating'] + +# Catch-all rule: move any unspecified app to workspace 10 (MUST BE LAST) +[[on-window-detected]] +run = ['move-node-to-workspace 10'] + diff --git a/mac/.config/sketchybar.mon/sketchybar/LICENSE b/mac/.config/sketchybar.mon/sketchybar/LICENSE new file mode 100644 index 0000000..8797b19 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2025 Pranav Sarda + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/mac/.config/sketchybar.mon/sketchybar/colors.sh b/mac/.config/sketchybar.mon/sketchybar/colors.sh new file mode 100755 index 0000000..bd78ee9 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/colors.sh @@ -0,0 +1,44 @@ +#!/bin/bash + +### Ultra Rich Color Theme + +# Deep, saturated base colors +export BLACK=0xff101014 +export WHITE=0xfff9f9fa +export RED=0xffff5370 +export GREEN=0xffb9f27c +export BLUE=0xff82aaff +export YELLOW=0xffffcb6b +export ORANGE=0xffff966c +export MAGENTA=0xffc792ea +export CYAN=0xff89ddff +export PURPLE=0xffbb80b3 +export GREY=0xff6c7086 +export LIGHT_GREY=0xffc3c7d1 +export DARK_GREY=0xff232634 +export TRANSPARENT=0x00000000 + +# Specialized ultra-rich colors +export BATTERY_1=0xffb9f27c # Ultra Rich Green - Full +export BATTERY_2=0xffffcb6b # Ultra Rich Yellow - High +export BATTERY_3=0xffff966c # Ultra Rich Orange - Medium +export BATTERY_4=0xffff5370 # Ultra Rich Red - Low +export BATTERY_5=0xffd7263d # Ultra Deep Red - Critical + +# General bar colors +export BAR_COLOR=$TRANSPARENT # Transparent bar +export BAR_BORDER_COLOR=0xff2a2a2a # Dark grey border +export BACKGROUND_1=0xff1e1e1e # Pure dark grey background for items +export BACKGROUND_2=0xff2a2a2a # Slightly lighter dark grey for borders +export ICON_COLOR=$WHITE # Ultra white icons +export LABEL_COLOR=$WHITE # Ultra white labels +export POPUP_BACKGROUND_COLOR=0xff232634 # Ultra rich dark popup background +export POPUP_BORDER_COLOR=0xff82aaff # Ultra rich blue popup border +export SHADOW_COLOR=$BLACK # Ultra black shadows + +# Ultra rich accent colors +export ACCENT_PRIMARY=0xff82aaff # Ultra Rich Blue +export ACCENT_SECONDARY=0xffb9f27c # Ultra Rich Green +export ACCENT_TERTIARY=0xffff966c # Ultra Rich Orange +export ACCENT_QUATERNARY=0xffc792ea # Ultra Rich Purple +export ACCENT_PINK=0xffff79c6 # Ultra Rich Pink diff --git a/mac/.config/sketchybar.mon/sketchybar/helper/cpu.h b/mac/.config/sketchybar.mon/sketchybar/helper/cpu.h new file mode 100644 index 0000000..c350ae3 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/helper/cpu.h @@ -0,0 +1,122 @@ +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> +#include <mach/mach.h> +#include <stdbool.h> +#include <time.h> + +#define MAX_TOPPROC_LEN 28 + +static const char TOPPROC[] = { "/bin/ps -Aceo pid,pcpu,comm -r" }; +static const char FILTER_PATTERN[] = { "com.apple." }; + +struct cpu { + host_t host; + mach_msg_type_number_t count; + host_cpu_load_info_data_t load; + host_cpu_load_info_data_t prev_load; + bool has_prev_load; + + char command[256]; +}; + +static inline void cpu_init(struct cpu* cpu) { + cpu->host = mach_host_self(); + cpu->count = HOST_CPU_LOAD_INFO_COUNT; + cpu->has_prev_load = false; + snprintf(cpu->command, 100, ""); +} + +static inline void cpu_update(struct cpu* cpu) { + kern_return_t error = host_statistics(cpu->host, + HOST_CPU_LOAD_INFO, + (host_info_t)&cpu->load, + &cpu->count ); + + if (error != KERN_SUCCESS) { + printf("Error: Could not read cpu host statistics.\n"); + return; + } + + if (cpu->has_prev_load) { + uint32_t delta_user = cpu->load.cpu_ticks[CPU_STATE_USER] + - cpu->prev_load.cpu_ticks[CPU_STATE_USER]; + + uint32_t delta_system = cpu->load.cpu_ticks[CPU_STATE_SYSTEM] + - cpu->prev_load.cpu_ticks[CPU_STATE_SYSTEM]; + + uint32_t delta_idle = cpu->load.cpu_ticks[CPU_STATE_IDLE] + - cpu->prev_load.cpu_ticks[CPU_STATE_IDLE]; + + double user_perc = (double)delta_user / (double)(delta_system + + delta_user + + delta_idle); + + double sys_perc = (double)delta_system / (double)(delta_system + + delta_user + + delta_idle); + + double total_perc = user_perc + sys_perc; + + FILE* file; + char line[1024]; + + file = popen(TOPPROC, "r"); + if (!file) { + printf("Error: TOPPROC command errored out...\n" ); + return; + } + + fgets(line, sizeof(line), file); + fgets(line, sizeof(line), file); + + char* start = strstr(line, FILTER_PATTERN); + char topproc[MAX_TOPPROC_LEN + 4]; + uint32_t caret = 0; + for (int i = 0; i < sizeof(line); i++) { + if (start && i == start - line) { + i+=9; + continue; + } + + if (caret >= MAX_TOPPROC_LEN && caret <= MAX_TOPPROC_LEN + 2) { + topproc[caret++] = '.'; + continue; + } + if (caret > MAX_TOPPROC_LEN + 2) break; + topproc[caret++] = line[i]; + if (line[i] == '\0') break; + } + + topproc[MAX_TOPPROC_LEN + 3] = '\0'; + + pclose(file); + + char color[16]; + if (total_perc >= .7) { + snprintf(color, 16, "%s", getenv("RED")); + } else if (total_perc >= .3) { + snprintf(color, 16, "%s", getenv("ORANGE")); + } else if (total_perc >= .1) { + snprintf(color, 16, "%s", getenv("YELLOW")); + } else { + snprintf(color, 16, "%s", getenv("LABEL_COLOR")); + } + + snprintf(cpu->command, 256, "--push cpu.sys %.2f " + "--push cpu.user %.2f " + "--set cpu.top label='%s' " + "--set cpu.percent label=%.0f%% label.color=%s ", + sys_perc, + user_perc, + topproc, + total_perc*100., + color ); + } + else { + snprintf(cpu->command, 256, ""); + } + + cpu->prev_load = cpu->load; + cpu->has_prev_load = true; +} diff --git a/mac/.config/sketchybar.mon/sketchybar/helper/helper b/mac/.config/sketchybar.mon/sketchybar/helper/helper Binary files differnew file mode 100755 index 0000000..050cca7 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/helper/helper diff --git a/mac/.config/sketchybar.mon/sketchybar/helper/helper.c b/mac/.config/sketchybar.mon/sketchybar/helper/helper.c new file mode 100644 index 0000000..71c3038 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/helper/helper.c @@ -0,0 +1,31 @@ +#include "cpu.h" +#include "sketchybar.h" + +struct cpu g_cpu; + +void handler(env env) { + // Environment variables passed from sketchybar can be accessed as seen below + char* name = env_get_value_for_key(env, "NAME"); + char* sender = env_get_value_for_key(env, "SENDER"); + char* info = env_get_value_for_key(env, "INFO"); + char* selected = env_get_value_for_key(env, "SELECTED"); + + if ((strcmp(name, "cpu.percent") == 0)) { + // CPU graph updates + cpu_update(&g_cpu); + + if (strlen(g_cpu.command) > 0) sketchybar(g_cpu.command); + } +} + +int main (int argc, char** argv) { + cpu_init(&g_cpu); + + if (argc < 2) { + printf("Usage: helper \"<bootstrap name>\"\n"); + exit(1); + } + + event_server_begin(handler, argv[1]); + return 0; +} diff --git a/mac/.config/sketchybar.mon/sketchybar/helper/makefile b/mac/.config/sketchybar.mon/sketchybar/helper/makefile new file mode 100644 index 0000000..ac8721a --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/helper/makefile @@ -0,0 +1,3 @@ + +helper: helper.c cpu.h sketchybar.h + clang -std=c99 -O3 helper.c -o helper diff --git a/mac/.config/sketchybar.mon/sketchybar/helper/sketchybar.h b/mac/.config/sketchybar.mon/sketchybar/helper/sketchybar.h new file mode 100644 index 0000000..2ab4c39 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/helper/sketchybar.h @@ -0,0 +1,209 @@ +#pragma once + +#include <mach/mach.h> +#include <mach/mach_port.h> +#include <mach/message.h> +#include <bootstrap.h> +#include <stdlib.h> +#include <pthread.h> +#include <stdio.h> + +typedef char* env; + +#define MACH_HANDLER(name) void name(env env) +typedef MACH_HANDLER(mach_handler); + +struct mach_message { + mach_msg_header_t header; + mach_msg_size_t msgh_descriptor_count; + mach_msg_ool_descriptor_t descriptor; +}; + +struct mach_buffer { + struct mach_message message; + mach_msg_trailer_t trailer; +}; + +struct mach_server { + bool is_running; + mach_port_name_t task; + mach_port_t port; + mach_port_t bs_port; + + pthread_t thread; + mach_handler* handler; +}; + +static struct mach_server g_mach_server; +static mach_port_t g_mach_port = 0; + +static inline char* env_get_value_for_key(env env, char* key) { + uint32_t caret = 0; + for(;;) { + if (!env[caret]) break; + if (strcmp(&env[caret], key) == 0) + return &env[caret + strlen(&env[caret]) + 1]; + + caret += strlen(&env[caret]) + + strlen(&env[caret + strlen(&env[caret]) + 1]) + + 2; + } + return (char*)""; +} + +static inline mach_port_t mach_get_bs_port() { + mach_port_name_t task = mach_task_self(); + + mach_port_t bs_port; + if (task_get_special_port(task, + TASK_BOOTSTRAP_PORT, + &bs_port ) != KERN_SUCCESS) { + return 0; + } + + mach_port_t port; + if (bootstrap_look_up(bs_port, + "git.felix.sketchybar", + &port ) != KERN_SUCCESS) { + return 0; + } + + return port; +} + +static inline void mach_receive_message(mach_port_t port, struct mach_buffer* buffer, bool timeout) { + *buffer = (struct mach_buffer) { 0 }; + mach_msg_return_t msg_return; + if (timeout) + msg_return = mach_msg(&buffer->message.header, + MACH_RCV_MSG | MACH_RCV_TIMEOUT, + 0, + sizeof(struct mach_buffer), + port, + 100, + MACH_PORT_NULL ); + else + msg_return = mach_msg(&buffer->message.header, + MACH_RCV_MSG, + 0, + sizeof(struct mach_buffer), + port, + MACH_MSG_TIMEOUT_NONE, + MACH_PORT_NULL ); + + if (msg_return != MACH_MSG_SUCCESS) { + buffer->message.descriptor.address = NULL; + } +} + +static inline char* mach_send_message(mach_port_t port, char* message, uint32_t len) { + if (!message || !port) { + return NULL; + } + + struct mach_message msg = { 0 }; + msg.header.msgh_remote_port = port; + msg.header.msgh_local_port = 0; + msg.header.msgh_id = 0; + msg.header.msgh_bits = MACH_MSGH_BITS_SET(MACH_MSG_TYPE_COPY_SEND, + MACH_MSG_TYPE_MAKE_SEND, + 0, + MACH_MSGH_BITS_COMPLEX ); + + msg.header.msgh_size = sizeof(struct mach_message); + msg.msgh_descriptor_count = 1; + msg.descriptor.address = message; + msg.descriptor.size = len * sizeof(char); + msg.descriptor.copy = MACH_MSG_VIRTUAL_COPY; + msg.descriptor.deallocate = false; + msg.descriptor.type = MACH_MSG_OOL_DESCRIPTOR; + + mach_msg(&msg.header, + MACH_SEND_MSG, + sizeof(struct mach_message), + 0, + MACH_PORT_NULL, + MACH_MSG_TIMEOUT_NONE, + MACH_PORT_NULL ); + + return NULL; +} + +#pragma clang diagnostic push +#pragma clang diagnostic ignored "-Wdeprecated-declarations" +static inline bool mach_server_begin(struct mach_server* mach_server, mach_handler handler, char* bootstrap_name) { + mach_server->task = mach_task_self(); + + if (mach_port_allocate(mach_server->task, + MACH_PORT_RIGHT_RECEIVE, + &mach_server->port ) != KERN_SUCCESS) { + return false; + } + + if (mach_port_insert_right(mach_server->task, + mach_server->port, + mach_server->port, + MACH_MSG_TYPE_MAKE_SEND) != KERN_SUCCESS) { + return false; + } + + if (task_get_special_port(mach_server->task, + TASK_BOOTSTRAP_PORT, + &mach_server->bs_port) != KERN_SUCCESS) { + return false; + } + + if (bootstrap_register(mach_server->bs_port, + bootstrap_name, + mach_server->port ) != KERN_SUCCESS) { + return false; + } + + mach_server->handler = handler; + mach_server->is_running = true; + struct mach_buffer buffer; + while (mach_server->is_running) { + mach_receive_message(mach_server->port, &buffer, false); + mach_server->handler((env)buffer.message.descriptor.address); + mach_msg_destroy(&buffer.message.header); + } + + return true; +} +#pragma clang diagnostic pop + +static inline char* sketchybar(char* message) { + uint32_t message_length = strlen(message) + 1; + char formatted_message[message_length + 1]; + + char quote = '\0'; + uint32_t caret = 0; + for (int i = 0; i < message_length; ++i) { + if (message[i] == '"' || message[i] == '\'') { + if (quote == message[i]) quote = '\0'; + else quote = message[i]; + continue; + } + formatted_message[caret] = message[i]; + if (message[i] == ' ' && !quote) formatted_message[caret] = '\0'; + caret++; + } + + if (caret > 0 && formatted_message[caret] == '\0' + && formatted_message[caret - 1] == '\0') { + caret--; + } + + formatted_message[caret] = '\0'; + if (!g_mach_port) g_mach_port = mach_get_bs_port(); + char* response = mach_send_message(g_mach_port, + formatted_message, + caret + 1 ); + + if (response) return response; + else return (char*)""; +} + +static inline void event_server_begin(mach_handler event_handler, char* bootstrap_name) { + mach_server_begin(&g_mach_server, event_handler, bootstrap_name); +} diff --git a/mac/.config/sketchybar.mon/sketchybar/icons.sh b/mac/.config/sketchybar.mon/sketchybar/icons.sh new file mode 100755 index 0000000..bee0dad --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/icons.sh @@ -0,0 +1,57 @@ +#!/bin/bash + +# General Icons +LOADING= +APPLE= +PREFERENCES= +ACTIVITY= +LOCK= +BELL= +BELL_DOT= + +# Git Icons +GIT_ISSUE= +GIT_DISCUSSION= +GIT_PULL_REQUEST= +GIT_COMMIT= +GIT_INDICATOR= + +# Spotify Icons +SPOTIFY_BACK= +SPOTIFY_PLAY_PAUSE= +SPOTIFY_NEXT= +SPOTIFY_SHUFFLE= +SPOTIFY_REPEAT= + +# Yabai Icons +YABAI_STACK= +YABAI_FULLSCREEN_ZOOM= +YABAI_PARENT_ZOOM= +YABAI_FLOAT= +YABAI_GRID= + +# Battery Icons +BATTERY_100= +BATTERY_75= +BATTERY_50= +BATTERY_25= +BATTERY_0= +BATTERY_CHARGING= + +# Volume Icons +VOLUME_100= +VOLUME_66= +VOLUME_33= +VOLUME_10= +VOLUME_0= + +# WiFi +WIFI_CONNECTED= +WIFI_DISCONNECTED= + +# svim +MODE_NORMAL= +MODE_INSERT= +MODE_VISUAL= +MODE_CMD= +MODE_PENDING= diff --git a/mac/.config/sketchybar.mon/sketchybar/items/apple.sh b/mac/.config/sketchybar.mon/sketchybar/items/apple.sh new file mode 100755 index 0000000..fde05b4 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/apple.sh @@ -0,0 +1,44 @@ +#!/bin/bash + +POPUP_OFF='sketchybar --set apple.logo popup.drawing=off' +POPUP_CLICK_SCRIPT='sketchybar --set $NAME popup.drawing=toggle' + +apple_logo=( + icon=$APPLE + icon.font="$FONT:Black:16.0" + icon.color=$WHITE + padding_right=15 + label.drawing=off + click_script="$POPUP_CLICK_SCRIPT" + popup.height=35 +) + +apple_prefs=( + icon=$PREFERENCES + label="Preferences" + click_script="open -a 'System Preferences'; $POPUP_OFF" +) + +apple_activity=( + icon=$ACTIVITY + label="Activity" + click_script="open -a 'Activity Monitor'; $POPUP_OFF" +) + +apple_lock=( + icon=$LOCK + label="Lock Screen" + click_script="pmset displaysleepnow; $POPUP_OFF" +) + +sketchybar --add item apple.logo left \ + --set apple.logo "${apple_logo[@]}" \ + \ + --add item apple.prefs popup.apple.logo \ + --set apple.prefs "${apple_prefs[@]}" \ + \ + --add item apple.activity popup.apple.logo \ + --set apple.activity "${apple_activity[@]}" \ + \ + --add item apple.lock popup.apple.logo \ + --set apple.lock "${apple_lock[@]}" diff --git a/mac/.config/sketchybar.mon/sketchybar/items/battery.sh b/mac/.config/sketchybar.mon/sketchybar/items/battery.sh new file mode 100755 index 0000000..7955060 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/battery.sh @@ -0,0 +1,16 @@ +#!/bin/sh + +battery=( + script="$PLUGIN_DIR/battery.sh" + icon.font="$FONT:Regular:19.0" + padding_right=3 + padding_left=0 + label.drawing=off + update_freq=120 + updates=on +) +sketchybar --add item battery right \ + --set battery "${battery[@]}"\ + icon.font.size=15 update_freq=120 script="$PLUGIN_DIR/battery.sh" \ + --subscribe battery power_source_change system_woke + diff --git a/mac/.config/sketchybar.mon/sketchybar/items/calendar.sh b/mac/.config/sketchybar.mon/sketchybar/items/calendar.sh new file mode 100755 index 0000000..62aadc8 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/calendar.sh @@ -0,0 +1,16 @@ +#!/bin/bash + +calendar=( + icon= + icon.font="$FONT:Black:12.0" + icon.padding_right=0 + label.align=right + padding_left=15 + update_freq=30 + script="$PLUGIN_DIR/calendar.sh" + click_script="$PLUGIN_DIR/zen.sh" +) + +sketchybar --add item calendar right \ + --set calendar "${calendar[@]}" \ + --subscribe calendar system_woke diff --git a/mac/.config/sketchybar.mon/sketchybar/items/cpu.sh b/mac/.config/sketchybar.mon/sketchybar/items/cpu.sh new file mode 100755 index 0000000..249595d --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/cpu.sh @@ -0,0 +1,53 @@ +#!/bin/bash + +cpu_top=( + label.font="$FONT:Semibold:7" + label=CPU + icon.drawing=off + width=0 + padding_right=15 + y_offset=6 +) + +cpu_percent=( + label.font="$FONT:Heavy:12" + label=CPU + y_offset=-4 + padding_right=15 + width=55 + icon.drawing=off + update_freq=4 + mach_helper="$HELPER" +) + +cpu_sys=( + width=0 + graph.color=$RED + graph.fill_color=$RED + label.drawing=off + icon.drawing=off + background.height=30 + background.drawing=on + background.color=$TRANSPARENT +) + +cpu_user=( + graph.color=$BLUE + label.drawing=off + icon.drawing=off + background.height=30 + background.drawing=on + background.color=$TRANSPARENT +) + +sketchybar --add item cpu.top right \ + --set cpu.top "${cpu_top[@]}" \ + \ + --add item cpu.percent right \ + --set cpu.percent "${cpu_percent[@]}" \ + \ + --add graph cpu.sys right 75 \ + --set cpu.sys "${cpu_sys[@]}" \ + \ + --add graph cpu.user right 75 \ + --set cpu.user "${cpu_user[@]}" diff --git a/mac/.config/sketchybar.mon/sketchybar/items/front_app.sh b/mac/.config/sketchybar.mon/sketchybar/items/front_app.sh new file mode 100755 index 0000000..77f79ff --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/front_app.sh @@ -0,0 +1,13 @@ +#!/bin/sh + +front_app=( + label.font="$FONT:Black:12.0" + icon.background.drawing=on + display=active + script="$PLUGIN_DIR/front_app.sh" + click_script="open -a 'Mission Control'" +) +sketchybar --add item front_app left \ + --set front_app "${front_app[@]}" \ + --subscribe front_app front_app_switched + diff --git a/mac/.config/sketchybar.mon/sketchybar/items/input_source.sh b/mac/.config/sketchybar.mon/sketchybar/items/input_source.sh new file mode 100755 index 0000000..c72f38f --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/input_source.sh @@ -0,0 +1,10 @@ +#!/bin/sh + +sketchybar --add item input_source right +sketchybar --set input_source \ + icon.font="$FONT:Regular:20.0" \ + script="$PLUGIN_DIR/get_input_source.sh" \ + icon.color=0xffffffff \ + update_freq=1 + + diff --git a/mac/.config/sketchybar.mon/sketchybar/items/spaces.sh b/mac/.config/sketchybar.mon/sketchybar/items/spaces.sh new file mode 100755 index 0000000..d4284aa --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/spaces.sh @@ -0,0 +1,81 @@ +#!/bin/sh + +#SPACE_ICONS=("1" "2" "3" "4") + +# Destroy space on right click, focus space on left click. +# New space by left clicking separator (>) + +sketchybar --add event aerospace_workspace_change +#echo $(aerospace list-workspaces --monitor 1 --visible no --empty no) >> ~/aaaa + +for m in $(aerospace list-monitors | awk '{print $1}'); do + for i in $(aerospace list-workspaces --monitor $m); do + sid=$i + space=( + space="$sid" + icon="$sid" + icon.highlight_color=$RED + icon.padding_left=10 + icon.padding_right=10 + display=$m + padding_left=2 + padding_right=2 + label.padding_right=20 + label.color=$GREY + label.highlight_color=$WHITE + label.font="sketchybar-app-font:Regular:16.0" + label.y_offset=-1 + background.color=$BACKGROUND_1 + background.border_color=$BACKGROUND_2 + script="$PLUGIN_DIR/space.sh" + ) + + sketchybar --add space space.$sid left \ + --set space.$sid "${space[@]}" \ + --subscribe space.$sid mouse.clicked + + apps=$(aerospace list-windows --workspace $sid | awk -F'|' '{gsub(/^ *| *$/, "", $2); print $2}') + + icon_strip=" " + if [ "${apps}" != "" ]; then + while read -r app + do + icon_strip+=" $($CONFIG_DIR/plugins/icon_map.sh "$app")" + done <<< "${apps}" + else + icon_strip=" —" + fi + + sketchybar --set space.$sid label="$icon_strip" + done + + for i in $(aerospace list-workspaces --monitor $m --empty); do + sketchybar --set space.$i display=0 + done + +done + + +space_creator=( + icon= + icon.font="$FONT:Heavy:16.0" + padding_left=10 + padding_right=8 + label.drawing=off + display=active + #click_script='yabai -m space --create' + script="$PLUGIN_DIR/space_windows.sh" + # script="$PLUGIN_DIR/aerospace.sh" + icon.color=$WHITE +) + +# sketchybar --add item space_creator left \ +# --set space_creator "${space_creator[@]}" \ +# --subscribe space_creator space_windows_change +sketchybar --add item space_creator left \ + --set space_creator "${space_creator[@]}" \ + --subscribe space_creator aerospace_workspace_change + +# sketchybar --add item change_windows left \ +# --set change_windows script="$PLUGIN_DIR/change_windows.sh" \ +# --subscribe change_windows space_changes diff --git a/mac/.config/sketchybar.mon/sketchybar/items/volume.sh b/mac/.config/sketchybar.mon/sketchybar/items/volume.sh new file mode 100755 index 0000000..bc9466d --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/volume.sh @@ -0,0 +1,43 @@ +#!/bin/sh + +volume_slider=( + script="$PLUGIN_DIR/volume.sh" + updates=on + label.drawing=off + icon.drawing=off + slider.highlight_color=$BLUE + slider.background.height=5 + slider.background.corner_radius=3 + slider.background.color=$BACKGROUND_2 + slider.knob= + slider.knob.drawing=on +) + +volume_icon=( + click_script="$PLUGIN_DIR/volume_click.sh" + padding_left=10 + icon=$VOLUME_100 + icon.width=0 + icon.align=left + icon.color=$GREY + icon.font="$FONT:Regular:14.0" + label.width=25 + label.align=left + label.font="$FONT:Regular:14.0" +) + +status_bracket=( + background.color=$BACKGROUND_1 + background.border_color=$BACKGROUND_2 +) + +sketchybar --add slider volume right \ + --set volume "${volume_slider[@]}" \ + --subscribe volume volume_change \ + mouse.clicked \ + --add item volume_icon right \ + --set volume_icon "${volume_icon[@]}" + +sketchybar --add bracket status brew github.bell wifi volume_icon \ + --set status "${status_bracket[@]}" + diff --git a/mac/.config/sketchybar.mon/sketchybar/items/weather.sh b/mac/.config/sketchybar.mon/sketchybar/items/weather.sh new file mode 100755 index 0000000..33b08d1 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/items/weather.sh @@ -0,0 +1,8 @@ +#!/bin/sh + +sketchybar --add item weather right \ + --set weather \ + script="$PLUGIN_DIR/weather.sh" \ + update_freq=1500 \ + --subscribe weather mouse.clicked + diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/aerospace.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/aerospace.sh new file mode 100755 index 0000000..b8825d5 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/aerospace.sh @@ -0,0 +1,117 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +WORKSPACE_ID="$1" + +# Get currently focused workspace +FOCUSED_WORKSPACE=$(aerospace list-workspaces --focused) + +# Get workspaces for each monitor +MONITOR_1_WORKSPACES=$(aerospace list-workspaces --monitor 1) +MONITOR_2_WORKSPACES=$(aerospace list-workspaces --monitor 2) + +# Check if this workspace is on monitor 1 or 2 +ON_MONITOR_1="" +ON_MONITOR_2="" + +for ws in $MONITOR_1_WORKSPACES; do + if [ "$ws" = "$WORKSPACE_ID" ]; then + ON_MONITOR_1="true" + break + fi +done + +for ws in $MONITOR_2_WORKSPACES; do + if [ "$ws" = "$WORKSPACE_ID" ]; then + ON_MONITOR_2="true" + break + fi +done + +# Show workspace if: +# 1. It's the currently focused workspace (global focus) +# 2. OR it's one of the "representative" workspaces from each monitor +SHOULD_SHOW="false" + +if [ "$WORKSPACE_ID" = "$FOCUSED_WORKSPACE" ]; then + # Always show the currently focused workspace + SHOULD_SHOW="true" +elif [ "$ON_MONITOR_1" = "true" ] && [ "$WORKSPACE_ID" = "1" ]; then + # Show workspace 1 as representative of monitor 1 + SHOULD_SHOW="true" +elif [ "$ON_MONITOR_2" = "true" ] && [ "$WORKSPACE_ID" = "4" ]; then + # Show workspace 4 as representative of monitor 2 (adjust this number as needed) + SHOULD_SHOW="true" +fi + +if [ "$SHOULD_SHOW" = "true" ]; then + # Show the workspace item + sketchybar --set "$NAME" drawing=on + + if [ "$WORKSPACE_ID" = "$FOCUSED_WORKSPACE" ]; then + # Active workspace styling - more noticeable text + sketchybar --set "$NAME" \ + background.drawing=on \ + background.color=$BACKGROUND_2 \ + background.corner_radius=6 \ + background.height=26 \ + background.border_width=0 \ + icon.color=$WHITE \ + icon.font="SF Pro:Semibold:14.0" \ + label.color=$WHITE + else + # Workspace visible on other display but not focused - subtle styling + sketchybar --set "$NAME" \ + background.drawing=on \ + background.color=$BACKGROUND_1 \ + background.corner_radius=6 \ + background.height=26 \ + background.border_width=0 \ + icon.color=$GREY \ + icon.font="SF Pro:Medium:14.0" \ + label.color=$GREY + fi +else + # Hide workspace that's not active on any display + sketchybar --set "$NAME" drawing=off +fi + + + +# MAIN_COLOR=0xffa17fa7 +# ACCENT_COLOR=0xffe19286 +# +# echo $NAME > ~/debug_skekychybar +# +# if [ "$1" = "change-focused-window" ]; then +# echo "change-focused-window" +# focused_window_info=$(aerospace list-windows --focused) +# focused_window_id=$(echo $focused_window_info | awk -F ' \\| ' '{print $1}') +# if [ "$2" = "$focused_window_id" ]; then +# sketchybar --set $NAME icon.color=$ACCENT_COLOR +# else +# sketchybar --set $NAME icon.color=$MAIN_COLOR +# fi +# fi +# +# if [ "$1" = "change-focused-workspace" ]; then +# echo "change-focused-workspace" +# focused_workspace=$(aerospace list-workspaces --focused) +# if [ "$2" = "$focused_workspace" ]; then +# sketchybar --set $NAME label.color=$ACCENT_COLOR +# else +# sketchybar --set $NAME label.color=$MAIN_COLOR +# fi +# fi +# +# if [ "$1" = "move-window-within-workspace" ]; then +# echo "move-window-within-workspace" +# focused_workspace=$(aerospace list-workspaces --focused) +# if [ "$2" = "$focused_workspace" ]; then +# sketchybar --set $NAME label.color=$ACCENT_COLOR +# else +# sketchybar --set $NAME label.color=$MAIN_COLOR +# fi +# fi diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/aerospace_display.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/aerospace_display.sh new file mode 100755 index 0000000..206666a --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/aerospace_display.sh @@ -0,0 +1,185 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Get all available monitors +AVAILABLE_MONITORS=$(aerospace list-monitors) +FOCUSED_WORKSPACE=$(aerospace list-workspaces --focused) + +# Create a cache file to store last known state +CACHE_FILE="/tmp/aerospace_display_state" + +# Map aerospace monitor IDs to our logical naming +# M1 = Primary (Built-in Retina Display) = aerospace monitor 2 +# M2 = External (MAG 274UPF E2) = aerospace monitor 1 +MONITOR_M1_ID="2" # Built-in Retina Display +MONITOR_M2_ID="1" # External Monitor + +# Check which monitors are currently connected +MONITOR_M1_CONNECTED=$(echo "$AVAILABLE_MONITORS" | grep "^$MONITOR_M1_ID " | wc -l) +MONITOR_M2_CONNECTED=$(echo "$AVAILABLE_MONITORS" | grep "^$MONITOR_M2_ID " | wc -l) + +# Function to get the current workspace for a monitor +get_current_workspace_for_monitor() { + local monitor_id="$1" + local workspaces=$(aerospace list-workspaces --monitor "$monitor_id" 2>/dev/null) + + # If monitor doesn't exist, return empty + if [ -z "$workspaces" ]; then + echo "" + return + fi + + # Check if the focused workspace is on this monitor + for ws in $workspaces; do + if [ "$ws" = "$FOCUSED_WORKSPACE" ]; then + echo "$ws" + return + fi + done + + # If focused workspace is not on this monitor, return cached value or first workspace + if [ -f "$CACHE_FILE" ]; then + local cached_ws=$(grep "^$monitor_id:" "$CACHE_FILE" | cut -d: -f2) + if [ -n "$cached_ws" ]; then + # Verify the cached workspace still exists on this monitor + for ws in $workspaces; do + if [ "$ws" = "$cached_ws" ]; then + echo "$cached_ws" + return + fi + done + fi + fi + + # Fallback to first workspace on this monitor + echo "$workspaces" | head -n1 +} + +# Update cache with current state +update_cache() { + local monitor_id="$1" + local workspace="$2" + + # Create or update cache file + if [ -f "$CACHE_FILE" ]; then + # Remove old entry for this monitor + grep -v "^$monitor_id:" "$CACHE_FILE" > "$CACHE_FILE.tmp" + mv "$CACHE_FILE.tmp" "$CACHE_FILE" + fi + + # Add current entry + echo "$monitor_id:$workspace" >> "$CACHE_FILE" +} + +# Get current workspace for each monitor (if connected) +MONITOR_M1_CURRENT="" +MONITOR_M2_CURRENT="" + +if [ "$MONITOR_M1_CONNECTED" -gt 0 ]; then + MONITOR_M1_CURRENT=$(get_current_workspace_for_monitor "$MONITOR_M1_ID") + if [ -n "$MONITOR_M1_CURRENT" ]; then + update_cache "$MONITOR_M1_ID" "$MONITOR_M1_CURRENT" + fi +fi + +if [ "$MONITOR_M2_CONNECTED" -gt 0 ]; then + MONITOR_M2_CURRENT=$(get_current_workspace_for_monitor "$MONITOR_M2_ID") + if [ -n "$MONITOR_M2_CURRENT" ]; then + update_cache "$MONITOR_M2_ID" "$MONITOR_M2_CURRENT" + fi +fi + +# Handle display logic based on what's connected +if [ "$MONITOR_M1_CONNECTED" -gt 0 ] && [ "$MONITOR_M2_CONNECTED" -gt 0 ]; then + # Both monitors connected - show both + sketchybar --set monitor_1_workspace \ + icon="M1:$MONITOR_M1_CURRENT" \ + drawing=on \ + icon.width=52 \ + icon.align=center \ + icon.padding_left=4 \ + icon.padding_right=4 \ + click_script="aerospace workspace $MONITOR_M1_CURRENT" + + sketchybar --set monitor_2_workspace \ + icon="M2:$MONITOR_M2_CURRENT" \ + drawing=on \ + icon.width=52 \ + icon.align=center \ + icon.padding_left=4 \ + icon.padding_right=4 \ + click_script="aerospace workspace $MONITOR_M2_CURRENT" + + # Highlight the currently focused workspace + if [ "$MONITOR_M1_CURRENT" = "$FOCUSED_WORKSPACE" ]; then + sketchybar --set monitor_1_workspace \ + icon.color=$WHITE \ + icon.font="SF Pro:Semibold:12.0" \ + background.color=$BACKGROUND_2 + + sketchybar --set monitor_2_workspace \ + icon.color=$GREY \ + icon.font="SF Pro:Medium:12.0" \ + background.color=$BACKGROUND_1 + elif [ "$MONITOR_M2_CURRENT" = "$FOCUSED_WORKSPACE" ]; then + sketchybar --set monitor_2_workspace \ + icon.color=$WHITE \ + icon.font="SF Pro:Semibold:12.0" \ + background.color=$BACKGROUND_2 + + sketchybar --set monitor_1_workspace \ + icon.color=$GREY \ + icon.font="SF Pro:Medium:12.0" \ + background.color=$BACKGROUND_1 + else + # Neither monitor has focus, show both as inactive + sketchybar --set monitor_1_workspace \ + icon.color=$GREY \ + icon.font="SF Pro:Medium:12.0" \ + background.color=$BACKGROUND_1 + + sketchybar --set monitor_2_workspace \ + icon.color=$GREY \ + icon.font="SF Pro:Medium:12.0" \ + background.color=$BACKGROUND_1 + fi + +elif [ "$MONITOR_M1_CONNECTED" -gt 0 ]; then + # Only M1 (primary) connected - show just the workspace number + sketchybar --set monitor_1_workspace \ + icon="$MONITOR_M1_CURRENT" \ + drawing=on \ + icon.color=$WHITE \ + icon.font="SF Pro:Semibold:14.0" \ + icon.width=32 \ + icon.align=center \ + icon.padding_left=4 \ + icon.padding_right=4 \ + background.color=$BACKGROUND_2 \ + click_script="aerospace workspace $MONITOR_M1_CURRENT" + + sketchybar --set monitor_2_workspace drawing=off + +elif [ "$MONITOR_M2_CONNECTED" -gt 0 ]; then + # Only M2 (external) connected - show just the workspace number + sketchybar --set monitor_2_workspace \ + icon="$MONITOR_M2_CURRENT" \ + drawing=on \ + icon.color=$WHITE \ + icon.font="SF Pro:Semibold:14.0" \ + icon.width=32 \ + icon.align=center \ + icon.padding_left=4 \ + icon.padding_right=4 \ + background.color=$BACKGROUND_2 \ + click_script="aerospace workspace $MONITOR_M2_CURRENT" + + sketchybar --set monitor_1_workspace drawing=off + +else + # No monitors detected - hide both (shouldn't happen) + sketchybar --set monitor_1_workspace drawing=off + sketchybar --set monitor_2_workspace drawing=off +fi
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/apple.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/apple.sh new file mode 100755 index 0000000..8a22606 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/apple.sh @@ -0,0 +1,38 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Create a simple popup menu for the Apple logo +sketchybar --set apple.logo popup.drawing=toggle + +# Check if popup is being shown +if [ "$(sketchybar --query apple.logo | jq -r '.popup.drawing')" = "on" ]; then + # Add popup items + sketchybar --add item apple.prefs popup.apple.logo \ + --set apple.prefs icon="" \ + icon.color=$BLUE \ + label="System Preferences" \ + click_script="open /System/Applications/System\ Preferences.app; sketchybar --set apple.logo popup.drawing=off" + + sketchybar --add item apple.activity popup.apple.logo \ + --set apple.activity icon="" \ + icon.color=$GREEN \ + label="Activity Monitor" \ + click_script="open /System/Applications/Utilities/Activity\ Monitor.app; sketchybar --set apple.logo popup.drawing=off" + + sketchybar --add item apple.lock popup.apple.logo \ + --set apple.lock icon="" \ + icon.color=$RED \ + label="Lock Screen" \ + click_script="pmset displaysleepnow; sketchybar --set apple.logo popup.drawing=off" + + sketchybar --add item apple.sleep popup.apple.logo \ + --set apple.sleep icon="" \ + icon.color=$YELLOW \ + label="Sleep" \ + click_script="pmset sleepnow; sketchybar --set apple.logo popup.drawing=off" +else + # Remove popup items when hiding + sketchybar --remove apple.prefs apple.activity apple.lock apple.sleep +fi diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/battery.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/battery.sh new file mode 100755 index 0000000..72535e2 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/battery.sh @@ -0,0 +1,48 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Get battery information +BATTERY_INFO=$(pmset -g batt | grep -Eo "[0-9]+%" | cut -d% -f1) +POWER_SOURCE=$(pmset -g ps | head -1) + +# Check if charging +if [[ $POWER_SOURCE == *"AC Power"* ]]; then + CHARGING=true +else + CHARGING=false +fi + +# Set battery level +BATTERY_LEVEL=$BATTERY_INFO + +# Determine icon and color based on battery level and charging status +if [[ $CHARGING == true ]]; then + ICON="" # Charging icon + COLOR=$ACCENT_SECONDARY +else + if [[ $BATTERY_LEVEL -gt 75 ]]; then + ICON="" # Full battery + COLOR=$BATTERY_1 + elif [[ $BATTERY_LEVEL -gt 50 ]]; then + ICON="" # Three quarters + COLOR=$BATTERY_2 + elif [[ $BATTERY_LEVEL -gt 25 ]]; then + ICON="" # Half battery + COLOR=$BATTERY_3 + elif [[ $BATTERY_LEVEL -gt 10 ]]; then + ICON="" # Quarter battery + COLOR=$BATTERY_4 + else + ICON="" # Empty battery + COLOR=$BATTERY_5 + fi +fi + +# Update the battery item +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label="$BATTERY_LEVEL%" \ + label.color=$WHITE \ + label.font="SF Pro:Medium:13.0" diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/bluetooth.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/bluetooth.sh new file mode 100755 index 0000000..d8dd1b6 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/bluetooth.sh @@ -0,0 +1,93 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Multiple methods to detect Bluetooth status +BT_ENABLED=false +AIRPODS_CONNECTED=false + +# Method 1: Check using defaults (most reliable) +BT_STATE=$(defaults read /Library/Preferences/com.apple.Bluetooth ControllerPowerState 2>/dev/null) +if [[ "$BT_STATE" == "1" ]]; then + BT_ENABLED=true +fi + +# Method 2: Check using system_profiler with better parsing +if [[ "$BT_ENABLED" == false ]]; then + BT_POWER=$(system_profiler SPBluetoothDataType 2>/dev/null | grep -i "state" | grep -i "on") + if [[ -n "$BT_POWER" ]]; then + BT_ENABLED=true + fi +fi + +# Method 3: Check if blueutil is available and use it (most accurate) +if command -v blueutil &> /dev/null; then + BT_UTIL_STATE=$(blueutil -p 2>/dev/null) + if [[ "$BT_UTIL_STATE" == "1" ]]; then + BT_ENABLED=true + elif [[ "$BT_UTIL_STATE" == "0" ]]; then + BT_ENABLED=false + fi +fi + +# Method 4: Check if any Bluetooth devices are connected as fallback +if [[ "$BT_ENABLED" == false ]]; then + BT_DEVICES=$(system_profiler SPBluetoothDataType 2>/dev/null | grep -i "connected: yes") + if [[ -n "$BT_DEVICES" ]]; then + BT_ENABLED=true + fi +fi + +# Check specifically for AirPods connection +if [[ "$BT_ENABLED" == true ]]; then + # Method 1: Check for AirPods in connected devices (SPBluetoothDataType) + AIRPODS_CHECK=$(system_profiler SPBluetoothDataType 2>/dev/null | grep -i -A 10 -B 2 "airpods\|air pods") + if [[ -n "$AIRPODS_CHECK" ]]; then + # Check if AirPods are actually connected (not just paired) + AIRPODS_CONNECTED_CHECK=$(echo "$AIRPODS_CHECK" | grep -i "connected: yes") + if [[ -n "$AIRPODS_CONNECTED_CHECK" ]]; then + AIRPODS_CONNECTED=true + fi + fi + + # Method 2: Check if AirPods are active audio device (more reliable) + if [[ "$AIRPODS_CONNECTED" == false ]]; then + AIRPODS_AUDIO_CHECK=$(system_profiler SPAudioDataType 2>/dev/null | grep -i -A 5 -B 5 "airpods") + if [[ -n "$AIRPODS_AUDIO_CHECK" ]]; then + # Check if AirPods are set as default output device + AIRPODS_DEFAULT_OUTPUT=$(echo "$AIRPODS_AUDIO_CHECK" | grep -i "default output device: yes") + if [[ -n "$AIRPODS_DEFAULT_OUTPUT" ]]; then + AIRPODS_CONNECTED=true + fi + fi + fi + + # Method 3: Alternative check using blueutil if available + if [[ "$AIRPODS_CONNECTED" == false ]] && command -v blueutil &> /dev/null; then + CONNECTED_DEVICES=$(blueutil --connected 2>/dev/null) + if [[ "$CONNECTED_DEVICES" == *"AirPods"* ]] || [[ "$CONNECTED_DEVICES" == *"Air Pods"* ]]; then + AIRPODS_CONNECTED=true + fi + fi +fi + +# Set icon and color based on connection status +if [[ "$AIRPODS_CONNECTED" == true ]]; then + # AirPods connected - AirPods icon in white + ICON="" + COLOR=$ACCENT_PINK +elif [[ "$BT_ENABLED" == true ]]; then + # Bluetooth enabled but no AirPods - blue Bluetooth icon + ICON="" + COLOR=$ACCENT_PRIMARY # Blue +else + # Bluetooth disabled - gray icon + ICON="" + COLOR=$GREY +fi + +# Update the Bluetooth item - icon only, no label +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label.drawing=off
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/calendar.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/calendar.sh new file mode 100755 index 0000000..013e3db --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/calendar.sh @@ -0,0 +1,117 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Get next calendar event +get_next_event() { + # Use EventKit to get calendar events + local event_info=$(osascript << 'EOF' +tell application "Calendar" + set currentDate to current date + set endOfDay to currentDate + (1 * days) + + set allEvents to {} + repeat with cal in calendars + set calEvents to (events of cal whose start date ≥ currentDate and start date ≤ endOfDay) + set allEvents to allEvents & calEvents + end repeat + + if (count of allEvents) > 0 then + set nextEvent to item 1 of allEvents + set eventStart to start date of nextEvent + set eventTitle to summary of nextEvent + + # Find the earliest upcoming event + repeat with evt in allEvents + if start date of evt < eventStart and start date of evt ≥ currentDate then + set nextEvent to evt + set eventStart to start date of evt + set eventTitle to summary of evt + end if + end repeat + + # Format the time properly + set eventHour to hours of eventStart + set eventMinute to minutes of eventStart + + # Convert to 12-hour format + if eventHour = 0 then + set displayHour to 12 + set ampm to "AM" + else if eventHour < 12 then + set displayHour to eventHour + set ampm to "AM" + else if eventHour = 12 then + set displayHour to 12 + set ampm to "PM" + else + set displayHour to eventHour - 12 + set ampm to "PM" + end if + + # Format minutes with leading zero if needed + if eventMinute < 10 then + set minuteStr to "0" & eventMinute + else + set minuteStr to eventMinute as string + end if + + set formattedTime to displayHour & ":" & minuteStr & " " & ampm + + set eventDate to date string of eventStart + set todayDate to date string of currentDate + + if eventDate = todayDate then + return eventTitle & "|" & formattedTime + else + return eventTitle & "|Tomorrow " & formattedTime + end if + else + return "No events" + end if +end tell +EOF +) + + echo "$event_info" +} + +# Get calendar information +EVENT_INFO=$(get_next_event 2>/dev/null) + +if [[ "$EVENT_INFO" == "No events" ]] || [[ -z "$EVENT_INFO" ]]; then + # No upcoming events + ICON="" + COLOR=$GREY + LABEL="No Events" +else + # Parse event information + IFS='|' read -r event_title event_time <<< "$EVENT_INFO" + + # Set icon and color based on time + if [[ "$event_time" == "Tomorrow"* ]]; then + ICON="" + COLOR=$ACCENT_QUATERNARY + else + ICON="" + COLOR=$ACCENT_PRIMARY + fi + + # Truncate long event titles + if [[ ${#event_title} -gt 15 ]]; then + event_title="${event_title:0:15}..." + fi + + # Create multi-line label using actual newline + LABEL="$event_title +$event_time" +fi + +# Update the Calendar item +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label="$LABEL" \ + label.color=$WHITE \ + label.font="SF Pro:Medium:12.0" \ + label.max_chars=20 diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/change_windows.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/change_windows.sh new file mode 100755 index 0000000..69364b8 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/change_windows.sh @@ -0,0 +1,3 @@ +#!/bin/bash + +echo change_windows.sh NAME: $NAME, SENDER: $SENDER >> ~/aaaa diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/clock.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/clock.sh new file mode 100755 index 0000000..f93c806 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/clock.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Get current time and date +TIME=$(date "+%I:%M %p") +DATE=$(date "+%a %d %b") + +# Format the label with both time and date +LABEL="$TIME $DATE" + +# Set the clock with enhanced styling +sketchybar --set "$NAME" label="$LABEL" \ + icon="" \ + icon.color=$YELLOW \ + label.color=$WHITE \ + label.font="SF Pro:Medium:13.0" + diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/clock_click.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/clock_click.sh new file mode 100755 index 0000000..e2419ad --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/clock_click.sh @@ -0,0 +1,43 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Create a popup showing calendar and date info +sketchybar --set clock popup.drawing=toggle + +# Check if popup is being shown +if [ "$(sketchybar --query clock | jq -r '.popup.drawing')" = "on" ]; then + # Get current date info + FULL_DATE=$(date "+%A, %B %d, %Y") + WEEK_NUMBER=$(date "+Week %V") + DAY_OF_YEAR=$(date "+Day %j of %Y") + + # Add date information items + sketchybar --add item clock.full_date popup.clock \ + --set clock.full_date icon="" \ + icon.color=$YELLOW \ + label="$FULL_DATE" \ + click_script="open /System/Applications/Calendar.app; sketchybar --set clock popup.drawing=off" + + sketchybar --add item clock.week popup.clock \ + --set clock.week icon="" \ + icon.color=$BLUE \ + label="$WEEK_NUMBER" \ + click_script="sketchybar --set clock popup.drawing=off" + + sketchybar --add item clock.day_of_year popup.clock \ + --set clock.day_of_year icon="" \ + icon.color=$GREEN \ + label="$DAY_OF_YEAR" \ + click_script="sketchybar --set clock popup.drawing=off" + + sketchybar --add item clock.calendar popup.clock \ + --set clock.calendar icon="" \ + icon.color=$ORANGE \ + label="Open Calendar" \ + click_script="open /System/Applications/Calendar.app; sketchybar --set clock popup.drawing=off" +else + # Remove popup items when hiding + sketchybar --remove clock.full_date clock.week clock.day_of_year clock.calendar +fi
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/cpu.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/cpu.sh new file mode 100755 index 0000000..dd55b0a --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/cpu.sh @@ -0,0 +1,37 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Get CPU usage percentage +CPU_USAGE=$(top -l 1 -n 0 | grep "CPU usage" | awk '{print $3}' | sed 's/%//') + +# Handle empty CPU usage +if [[ -z "$CPU_USAGE" ]]; then + CPU_USAGE=0 +fi + +# Remove decimal point for comparison +CPU_INT=${CPU_USAGE%.*} + +# Set icon and color based on CPU usage +if [[ $CPU_INT -le 25 ]]; then + ICON="" # Low CPU + COLOR=$ACCENT_SECONDARY # Green +elif [[ $CPU_INT -le 50 ]]; then + ICON="" # Medium CPU + COLOR=$ACCENT_PRIMARY # Blue +elif [[ $CPU_INT -le 75 ]]; then + ICON="" # High CPU + COLOR=$ACCENT_TERTIARY # Orange +else + ICON="" # Very High CPU + COLOR=$RED # Red +fi + +# Update the CPU item +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label="$CPU_USAGE%" \ + label.color=$WHITE \ + label.font="SF Pro:Medium:12.0" diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/front_app.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/front_app.sh new file mode 100755 index 0000000..fcae89d --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/front_app.sh @@ -0,0 +1,104 @@ +#!/usr/bin/env bash + +# Source colors and icons for consistent theming +source "$CONFIG_DIR/colors.sh" +source "$CONFIG_DIR/icons.sh" + +# Get the current application +if [ "$SENDER" = "front_app_switched" ]; then + APP_NAME="$INFO" +else + APP_NAME=$(yabai -m query --windows --window | jq -r '.app' 2>/dev/null || echo "$(osascript -e 'tell application "System Events" to get name of first application process whose frontmost is true')") +fi + +# Icon mapping for common applications +case $APP_NAME in + "Cursor") + ICON="" + ;; + "Visual Studio Code") + ICON="" + ;; + "Slack") + ICON="" + ;; + "Discord") + ICON="" + ;; + "Google Chrome") + ICON="" + ;; + "Safari") + ICON="" + ;; + "Firefox") + ICON="" + ;; + "Terminal") + ICON="" + ;; + "iTerm2") + ICON="" + ;; + "Finder") + ICON="" + ;; + "Spotify") + ICON="" + ;; + "Music") + ICON="" + ;; + "Mail") + ICON="" + ;; + "Messages") + ICON="" + ;; + "FaceTime") + ICON="" + ;; + "Zoom") + ICON="" + ;; + "Notion") + ICON="" + ;; + "Obsidian") + ICON="" + ;; + "Xcode") + ICON="" + ;; + "Docker") + ICON="" + ;; + "Figma") + ICON="" + ;; + "Sketch") + ICON="" + ;; + "Photoshop") + ICON="" + ;; + "System Preferences") + ICON="" + ;; + "System Settings") + ICON="" + ;; + "Activity Monitor") + ICON="" + ;; + *) + # Default icon for unknown applications + ICON="" + ;; +esac + +# Update the front_app item +sketchybar --set "$NAME" icon="$ICON" \ + icon.color=$ACCENT_QUATERNARY \ + label="$APP_NAME" \ + label.color=$WHITE diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/get_input_source.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/get_input_source.sh new file mode 100755 index 0000000..89dab2b --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/get_input_source.sh @@ -0,0 +1,13 @@ +#!/bin/sh + +# hangul and english item + +# Read the plist data +plist_data=$(defaults read ~/Library/Preferences/com.apple.HIToolbox.plist AppleSelectedInputSources) +current_input_source=$(echo "$plist_data" | plutil -convert xml1 -o - - | grep -A1 'KeyboardLayout Name' | tail -n1 | cut -d '>' -f2 | cut -d '<' -f1) + +if [ "$current_input_source" = "ABC" ]; then + sketchybar --set input_source icon="" +else + sketchybar --set input_source icon="" +fi diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/icon_map.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/icon_map.sh new file mode 100755 index 0000000..e23f8d0 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/icon_map.sh @@ -0,0 +1,637 @@ +#!/usr/bin/env bash + +### START-OF-ICON-MAP +function __icon_map() { + case "$1" in + "Live") + icon_result=":ableton:" + ;; + "Adobe Bridge"*) + icon_result=":adobe_bridge:" + ;; + "Affinity Designer") + icon_result=":affinity_designer:" + ;; + "Affinity Designer 2") + icon_result=":affinity_designer_2:" + ;; + "Affinity Photo") + icon_result=":affinity_photo:" + ;; + "Affinity Photo 2") + icon_result=":affinity_photo_2:" + ;; + "Affinity Publisher") + icon_result=":affinity_publisher:" + ;; + "Affinity Publisher 2") + icon_result=":affinity_publisher_2:" + ;; + "Airmail") + icon_result=":airmail:" + ;; + "Alacritty") + icon_result=":alacritty:" + ;; + "Alfred") + icon_result=":alfred:" + ;; + "Android Messages") + icon_result=":android_messages:" + ;; + "Android Studio") + icon_result=":android_studio:" + ;; + "Anytype") + icon_result=":anytype:" + ;; + "App Eraser") + icon_result=":app_eraser:" + ;; + "App Store") + icon_result=":app_store:" + ;; + "Arc") + icon_result=":arc:" + ;; + "Atom") + icon_result=":atom:" + ;; + "Audacity") + icon_result=":audacity:" + ;; + "Bambu Studio") + icon_result=":bambu_studio:" + ;; + "MoneyMoney") + icon_result=":bank:" + ;; + "Battle.net") + icon_result=":battle_net:" + ;; + "Bear") + icon_result=":bear:" + ;; + "BetterTouchTool") + icon_result=":bettertouchtool:" + ;; + "Bilibili" | "哔哩哔哩") + icon_result=":bilibili:" + ;; + "Bitwarden") + icon_result=":bit_warden:" + ;; + "Blender") + icon_result=":blender:" + ;; + "BluOS Controller") + icon_result=":bluos_controller:" + ;; + "Calibre") + icon_result=":book:" + ;; + "Brave Browser") + icon_result=":brave_browser:" + ;; + "Calculator" | "Calculette") + icon_result=":calculator:" + ;; + "Calendar" | "日历" | "Fantastical" | "Cron" | "Amie" | "Calendrier" | "Notion Calendar") + icon_result=":calendar:" + ;; + "Caprine") + icon_result=":caprine:" + ;; + "Citrix Workspace" | "Citrix Viewer") + icon_result=":citrix:" + ;; + "ClickUp") + icon_result=":click_up:" + ;; + "Code" | "Code - Insiders") + icon_result=":code:" + ;; + "Color Picker" | "数码测色计") + icon_result=":color_picker:" + ;; + "CotEditor") + icon_result=":coteditor:" + ;; + "Creative Cloud") + icon_result=":creative_cloud:" + ;; + "Cypress") + icon_result=":cypress:" + ;; + "DataGrip") + icon_result=":datagrip:" + ;; + "DataSpell") + icon_result=":dataspell:" + ;; + "DaVinci Resolve") + icon_result=":davinciresolve:" + ;; + "Default") + icon_result=":default:" + ;; + "CleanMyMac X") + icon_result=":desktop:" + ;; + "DEVONthink 3") + icon_result=":devonthink3:" + ;; + "DingTalk" | "钉钉" | "阿里钉") + icon_result=":dingtalk:" + ;; + "Discord" | "Discord Canary" | "Discord PTB") + icon_result=":discord:" + ;; + "Docker" | "Docker Desktop") + icon_result=":docker:" + ;; + "GrandTotal" | "Receipts") + icon_result=":dollar:" + ;; + "Double Commander") + icon_result=":doublecmd:" + ;; + "Drafts") + icon_result=":drafts:" + ;; + "Dropbox") + icon_result=":dropbox:" + ;; + "Element") + icon_result=":element:" + ;; + "Emacs") + icon_result=":emacs:" + ;; + "Evernote Legacy") + icon_result=":evernote_legacy:" + ;; + "FaceTime" | "FaceTime 通话") + icon_result=":face_time:" + ;; + "Figma") + icon_result=":figma:" + ;; + "Final Cut Pro") + icon_result=":final_cut_pro:" + ;; + "Finder" | "访达") + icon_result=":finder:" + ;; + "Firefox") + icon_result=":firefox:" + ;; + "Firefox Developer Edition" | "Firefox Nightly") + icon_result=":firefox_developer_edition:" + ;; + "Folx") + icon_result=":folx:" + ;; + "Fusion") + icon_result=":fusion:" + ;; + "System Preferences" | "System Settings" | "系统设置" | "Réglages Système") + icon_result=":gear:" + ;; + "GitHub Desktop") + icon_result=":git_hub:" + ;; + "Godot") + icon_result=":godot:" + ;; + "GoLand") + icon_result=":goland:" + ;; + "Chromium" | "Google Chrome" | "Google Chrome Canary") + icon_result=":google_chrome:" + ;; + "Grammarly Editor") + icon_result=":grammarly:" + ;; + "Home Assistant") + icon_result=":home_assistant:" + ;; + "Hyper") + icon_result=":hyper:" + ;; + "IntelliJ IDEA") + icon_result=":idea:" + ;; + "Inkdrop") + icon_result=":inkdrop:" + ;; + "Inkscape") + icon_result=":inkscape:" + ;; + "Insomnia") + icon_result=":insomnia:" + ;; + "Iris") + icon_result=":iris:" + ;; + "iTerm" | "iTerm2") + icon_result=":iterm:" + ;; + "Jellyfin Media Player") + icon_result=":jellyfin:" + ;; + "Joplin") + icon_result=":joplin:" + ;; + "카카오톡" | "KakaoTalk") + icon_result=":kakaotalk:" + ;; + "Kakoune") + icon_result=":kakoune:" + ;; + "KeePassXC") + icon_result=":kee_pass_x_c:" + ;; + "Keyboard Maestro") + icon_result=":keyboard_maestro:" + ;; + "Keynote" | "Keynote 讲演") + icon_result=":keynote:" + ;; + "kitty") + icon_result=":kitty:" + ;; + "League of Legends") + icon_result=":league_of_legends:" + ;; + "LibreWolf") + icon_result=":libre_wolf:" + ;; + "Adobe Lightroom") + icon_result=":lightroom:" + ;; + "Lightroom Classic") + icon_result=":lightroomclassic:" + ;; + "LINE") + icon_result=":line:" + ;; + "Linear") + icon_result=":linear:" + ;; + "LM Studio") + icon_result=":lm_studio:" + ;; + "LocalSend") + icon_result=":localsend:" + ;; + "Logic Pro") + icon_result=":logicpro:" + ;; + "Logseq") + icon_result=":logseq:" + ;; + "Canary Mail" | "HEY" | "Mail" | "Mailspring" | "MailMate" | "Superhuman" | "Spark" | "邮件") + icon_result=":mail:" + ;; + "MAMP" | "MAMP PRO") + icon_result=":mamp:" + ;; + "Maps" | "Google Maps") + icon_result=":maps:" + ;; + "Matlab") + icon_result=":matlab:" + ;; + "Mattermost") + icon_result=":mattermost:" + ;; + "Messages" | "信息" | "Nachrichten") + icon_result=":messages:" + ;; + "Messenger") + icon_result=":messenger:" + ;; + "Microsoft Edge") + icon_result=":microsoft_edge:" + ;; + "Microsoft Excel") + icon_result=":microsoft_excel:" + ;; + "Microsoft Outlook") + icon_result=":microsoft_outlook:" + ;; + "Microsoft PowerPoint") + icon_result=":microsoft_power_point:" + ;; + "Microsoft Remote Desktop") + icon_result=":microsoft_remote_desktop:" + ;; + "Microsoft Teams" | "Microsoft Teams (work or school)") + icon_result=":microsoft_teams:" + ;; + "Microsoft Word") + icon_result=":microsoft_word:" + ;; + "Min") + icon_result=":min_browser:" + ;; + "Miro") + icon_result=":miro:" + ;; + "MongoDB Compass"*) + icon_result=":mongodb:" + ;; + "mpv") + icon_result=":mpv:" + ;; + "Mullvad Browser") + icon_result=":mullvad_browser:" + ;; + "Music" | "音乐" | "Musique") + icon_result=":music:" + ;; + "Neovide" | "neovide") + icon_result=":neovide:" + ;; + "Neovim" | "neovim" | "nvim") + icon_result=":neovim:" + ;; + "网易云音乐") + icon_result=":netease_music:" + ;; + "Noodl" | "Noodl Editor") + icon_result=":noodl:" + ;; + "NordVPN") + icon_result=":nord_vpn:" + ;; + "Notability") + icon_result=":notability:" + ;; + "Notes" | "备忘录") + icon_result=":notes:" + ;; + "Notion") + icon_result=":notion:" + ;; + "Nova") + icon_result=":nova:" + ;; + "Numbers" | "Numbers 表格") + icon_result=":numbers:" + ;; + "Obsidian") + icon_result=":obsidian:" + ;; + "OBS") + icon_result=":obsstudio:" + ;; + "OmniFocus") + icon_result=":omni_focus:" + ;; + "1Password") + icon_result=":one_password:" + ;; + "ChatGPT") + icon_result=":openai:" + ;; + "OpenVPN Connect") + icon_result=":openvpn_connect:" + ;; + "Opera") + icon_result=":opera:" + ;; + "OrcaSlicer") + icon_result=":orcaslicer:" + ;; + "Orion" | "Orion RC") + icon_result=":orion:" + ;; + "Pages" | "Pages 文稿") + icon_result=":pages:" + ;; + "Parallels Desktop") + icon_result=":parallels:" + ;; + "Parsec") + icon_result=":parsec:" + ;; + "Preview" | "预览" | "Skim" | "zathura" | "Aperçu") + icon_result=":pdf:" + ;; + "PDF Expert") + icon_result=":pdf_expert:" + ;; + "Adobe Photoshop"*) + icon_result=":photoshop:" + ;; + "PhpStorm") + icon_result=":php_storm:" + ;; + "Pi-hole Remote") + icon_result=":pihole:" + ;; + "Pine") + icon_result=":pine:" + ;; + "Podcasts" | "播客") + icon_result=":podcasts:" + ;; + "PomoDone App") + icon_result=":pomodone:" + ;; + "Postman") + icon_result=":postman:" + ;; + "Proton Mail" | "Proton Mail Bridge") + icon_result=":proton_mail:" + ;; + "PrusaSlicer" | "SuperSlicer") + icon_result=":prusaslicer:" + ;; + "PyCharm") + icon_result=":pycharm:" + ;; + "QQ") + icon_result=":qq:" + ;; + "QQ音乐" | "QQMusic") + icon_result=":qqmusic:" + ;; + "Quantumult X") + icon_result=":quantumult_x:" + ;; + "qutebrowser") + icon_result=":qute_browser:" + ;; + "Raindrop.io") + icon_result=":raindrop_io:" + ;; + "Reeder") + icon_result=":reeder5:" + ;; + "Reminders" | "提醒事项" | "Rappels") + icon_result=":reminders:" + ;; + "Replit") + icon_result=":replit:" + ;; + "Rider" | "JetBrains Rider") + icon_result=":rider:" + ;; + "Safari" | "Safari浏览器" | "Safari Technology Preview") + icon_result=":safari:" + ;; + "Sequel Ace") + icon_result=":sequel_ace:" + ;; + "Sequel Pro") + icon_result=":sequel_pro:" + ;; + "Setapp") + icon_result=":setapp:" + ;; + "SF Symbols") + icon_result=":sf_symbols:" + ;; + "Signal") + icon_result=":signal:" + ;; + "Sketch") + icon_result=":sketch:" + ;; + "Skype") + icon_result=":skype:" + ;; + "Slack") + icon_result=":slack:" + ;; + "Spark Desktop") + icon_result=":spark:" + ;; + "Spotify") + icon_result=":spotify:" + ;; + "Spotlight") + icon_result=":spotlight:" + ;; + "Sublime Text") + icon_result=":sublime_text:" + ;; + "Tana") + icon_result=":tana:" + ;; + "TeamSpeak 3") + icon_result=":team_speak:" + ;; + "Telegram") + icon_result=":telegram:" + ;; + "Terminal" | "终端") + icon_result=":terminal:" + ;; + "Typora") + icon_result=":text:" + ;; + "Microsoft To Do" | "Things") + icon_result=":things:" + ;; + "Thunderbird") + icon_result=":thunderbird:" + ;; + "TickTick") + icon_result=":tick_tick:" + ;; + "TIDAL") + icon_result=":tidal:" + ;; + "Tiny RDM") + icon_result=":tinyrdm:" + ;; + "Todoist") + icon_result=":todoist:" + ;; + "Toggl Track") + icon_result=":toggl_track:" + ;; + "Tor Browser") + icon_result=":tor_browser:" + ;; + "Tower") + icon_result=":tower:" + ;; + "Transmit") + icon_result=":transmit:" + ;; + "Trello") + icon_result=":trello:" + ;; + "Tweetbot" | "Twitter") + icon_result=":twitter:" + ;; + "MacVim" | "Vim" | "VimR") + icon_result=":vim:" + ;; + "Vivaldi") + icon_result=":vivaldi:" + ;; + "VLC") + icon_result=":vlc:" + ;; + "VMware Fusion") + icon_result=":vmware_fusion:" + ;; + "VSCodium") + icon_result=":vscodium:" + ;; + "Warp") + icon_result=":warp:" + ;; + "WebStorm") + icon_result=":web_storm:" + ;; + "微信" | "WeChat") + icon_result=":wechat:" + ;; + "企业微信" | "WeCom") + icon_result=":wecom:" + ;; + "WezTerm") + icon_result=":wezterm:" + ;; + "WhatsApp" | "WhatsApp") + icon_result=":whats_app:" + ;; + "Xcode") + icon_result=":xcode:" + ;; + "Яндекс Музыка") + icon_result=":yandex_music:" + ;; + "Yuque" | "语雀") + icon_result=":yuque:" + ;; + "Zed") + icon_result=":zed:" + ;; + "Zeplin") + icon_result=":zeplin:" + ;; + "zoom.us") + icon_result=":zoom:" + ;; + "Zotero") + icon_result=":zotero:" + ;; + "Zulip") + icon_result=":zulip:" + ;; + *) + icon_result=":default:" + ;; + esac +} +### END-OF-ICON-MAP +__icon_map "$1" +echo "$icon_result" diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/monitor_watcher.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/monitor_watcher.sh new file mode 100755 index 0000000..50868d3 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/monitor_watcher.sh @@ -0,0 +1,25 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Store current monitor state to detect changes +MONITOR_STATE_FILE="/tmp/aerospace_monitor_state" + +# Get current monitor state +CURRENT_MONITORS=$(aerospace list-monitors | awk '{print $1}' | sort | tr '\n' ' ') + +# Check if state has changed +if [ -f "$MONITOR_STATE_FILE" ]; then + PREVIOUS_MONITORS=$(cat "$MONITOR_STATE_FILE") + if [ "$CURRENT_MONITORS" != "$PREVIOUS_MONITORS" ]; then + # Monitor configuration changed, update display + "$CONFIG_DIR/plugins/aerospace_display.sh" + fi +else + # First run, create state file + "$CONFIG_DIR/plugins/aerospace_display.sh" +fi + +# Save current state +echo "$CURRENT_MONITORS" > "$MONITOR_STATE_FILE"
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/now_playing.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/now_playing.sh new file mode 100755 index 0000000..0ae68c7 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/now_playing.sh @@ -0,0 +1,77 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Function to get Spotify info +get_spotify_info() { + local state=$(osascript -e 'tell application "Spotify" to player state as string' 2>/dev/null) + if [[ "$state" == "playing" ]]; then + local artist=$(osascript -e 'tell application "Spotify" to artist of current track as string' 2>/dev/null) + local track=$(osascript -e 'tell application "Spotify" to name of current track as string' 2>/dev/null) + echo "playing|$artist|$track" + elif [[ "$state" == "paused" ]]; then + echo "paused" + else + echo "stopped" + fi +} + +# Function to get Apple Music info +get_apple_music_info() { + local state=$(osascript -e 'tell application "Music" to player state as string' 2>/dev/null) + if [[ "$state" == "playing" ]]; then + local artist=$(osascript -e 'tell application "Music" to artist of current track as string' 2>/dev/null) + local track=$(osascript -e 'tell application "Music" to name of current track as string' 2>/dev/null) + echo "playing|$artist|$track" + elif [[ "$state" == "paused" ]]; then + echo "paused" + else + echo "stopped" + fi +} + +# Check Spotify first, then Apple Music +SPOTIFY_INFO=$(get_spotify_info) +APPLE_MUSIC_INFO=$(get_apple_music_info) + +if [[ "$SPOTIFY_INFO" == "playing|"* ]]; then + # Spotify is playing - show the item + sketchybar --set "$NAME" drawing=on + ICON="" + COLOR=$ACCENT_SECONDARY + IFS='|' read -r state artist track <<< "$SPOTIFY_INFO" + if [[ ${#track} -gt 20 ]]; then + LABEL="${track:0:20}..." + else + LABEL="$track" + fi +elif [[ "$APPLE_MUSIC_INFO" == "playing|"* ]]; then + # Apple Music is playing - show the item + sketchybar --set "$NAME" drawing=on + ICON="" + COLOR=$ACCENT_QUATERNARY + IFS='|' read -r state artist track <<< "$APPLE_MUSIC_INFO" + if [[ ${#track} -gt 20 ]]; then + LABEL="${track:0:20}..." + else + LABEL="$track" + fi +elif [[ "$SPOTIFY_INFO" == "paused" ]] || [[ "$APPLE_MUSIC_INFO" == "paused" ]]; then + # Music is paused - show paused state + sketchybar --set "$NAME" drawing=on + ICON="" + COLOR=$ACCENT_TERTIARY + LABEL="Paused" +else + # No music playing - hide the item completely + sketchybar --set "$NAME" drawing=off + exit 0 +fi + +# Update the Now Playing item (only if we're showing it) +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label="$LABEL" \ + label.color=$WHITE \ + label.font="SF Pro:Medium:12.0"
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/space.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/space.sh new file mode 100755 index 0000000..b8602b5 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/space.sh @@ -0,0 +1,7 @@ +#!/bin/sh + +# The $SELECTED variable is available for space components and indicates if +# the space invoking this script (with name: $NAME) is currently selected: +# https://felixkratz.github.io/SketchyBar/config/components#space----associate-mission-control-spaces-with-an-item + +sketchybar --set "$NAME" background.drawing="$SELECTED" diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/space_windows.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/space_windows.sh new file mode 100755 index 0000000..c8996cb --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/space_windows.sh @@ -0,0 +1,87 @@ +#!/usr/bin/env bash + +echo AEROSPACE_PREV_WORKSPACE: $AEROSPACE_PREV_WORKSPACE, \ + AEROSPACE_FOCUSED_WORKSPACE: $AEROSPACE_FOCUSED_WORKSPACE \ + SELECTED: $SELECTED \ + BG2: $BG2 \ + INFO: $INFO \ + SENDER: $SENDER \ + NAME: $NAME \ + >> ~/aaaa + +source "$CONFIG_DIR/colors.sh" + +AEROSPACE_FOCUSED_MONITOR=$(aerospace list-monitors --focused | awk '{print $1}') +AEROSAPCE_WORKSPACE_FOCUSED_MONITOR=$(aerospace list-workspaces --monitor focused --empty no) +AEROSPACE_EMPTY_WORKESPACE=$(aerospace list-workspaces --monitor focused --empty) + +reload_workspace_icon() { + # echo reload_workspace_icon "$@" >> ~/aaaa + apps=$(aerospace list-windows --workspace "$@" | awk -F'|' '{gsub(/^ *| *$/, "", $2); print $2}') + + icon_strip=" " + if [ "${apps}" != "" ]; then + while read -r app + do + icon_strip+=" $($CONFIG_DIR/plugins/icon_map.sh "$app")" + done <<< "${apps}" + else + icon_strip=" —" + fi + + sketchybar --animate sin 10 --set space.$@ label="$icon_strip" +} + +if [ "$SENDER" = "aerospace_workspace_change" ]; then + + # if [ $i = "$FOCUSED_WORKSPACE" ]; then + # sketchybar --set space.$FOCUSED_WORKSPACE background.drawing=on + # else + # sketchybar --set space.$FOCUSED_WORKSPACE background.drawing=off + # fi + #echo 'space_windows_change: '$AEROSPACE_FOCUSED_WORKSPACE >> ~/aaaa + #echo space: $space >> ~/aaaa + #space="$(echo "$INFO" | jq -r '.space')" + #apps="$(echo "$INFO" | jq -r '.apps | keys[]')" + # apps=$(aerospace list-windows --workspace $AEROSPACE_FOCUSED_WORKSPACE | awk -F'|' '{gsub(/^ *| *$/, "", $2); print $2}') + # + # icon_strip=" " + # if [ "${apps}" != "" ]; then + # while read -r app + # do + # icon_strip+=" $($CONFIG_DIR/plugins/icon_map.sh "$app")" + # done <<< "${apps}" + # else + # icon_strip=" —" + # fi + + reload_workspace_icon "$AEROSPACE_PREV_WORKSPACE" + reload_workspace_icon "$AEROSPACE_FOCUSED_WORKSPACE" + + #sketchybar --animate sin 10 --set space.$space label="$icon_strip" + + # current workspace space border color + sketchybar --set space.$AEROSPACE_FOCUSED_WORKSPACE icon.highlight=true \ + label.highlight=true \ + background.border_color=$GREY + + # prev workspace space border color + sketchybar --set space.$AEROSPACE_PREV_WORKSPACE icon.highlight=false \ + label.highlight=false \ + background.border_color=$BACKGROUND_2 + + # if [ "$AEROSPACE_FOCUSED_WORKSPACE" -gt 3 ]; then + # sketchybar --animate sin 10 --set space.$AEROSPACE_FOCUSED_WORKSPACE display=1 + # fi + ## focused 된 모니터에 space 상태 보이게 설정 + for i in $AEROSAPCE_WORKSPACE_FOCUSED_MONITOR; do + sketchybar --set space.$i display=$AEROSPACE_FOCUSED_MONITOR + done + + for i in $AEROSPACE_EMPTY_WORKESPACE; do + sketchybar --set space.$i display=0 + done + + sketchybar --set space.$AEROSPACE_FOCUSED_WORKSPACE display=$AEROSPACE_FOCUSED_MONITOR + +fi diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/test_click.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/test_click.sh new file mode 100644 index 0000000..7cb66f2 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/test_click.sh @@ -0,0 +1,3 @@ +#/bin/bash -c + +osascript -e 'display notification "Volume clicked' diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/volume.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/volume.sh new file mode 100755 index 0000000..6135b1f --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/volume.sh @@ -0,0 +1,77 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Get volume information +if [ "$SENDER" = "volume_change" ]; then + VOLUME="$INFO" + # Check if muted by trying to get current mute state + MUTED=$(osascript -e "output muted of (get volume settings)" 2>/dev/null) +else + VOLUME=$(osascript -e "output volume of (get volume settings)" 2>/dev/null) + MUTED=$(osascript -e "output muted of (get volume settings)" 2>/dev/null) +fi + +# Fallback if osascript fails +if [[ -z "$VOLUME" ]]; then + VOLUME=50 +fi + +# Determine icon and color based on volume level and mute status +if [[ $MUTED == "true" ]]; then + ICON="" # Muted icon + COLOR=$RED + LABEL="" # No label for muted state since we're not showing labels +else + if [[ $VOLUME -gt 75 ]]; then + ICON="" # High volume + COLOR=$ACCENT_PRIMARY + elif [[ $VOLUME -gt 50 ]]; then + ICON="" # Medium volume + COLOR=$ACCENT_PRIMARY + elif [[ $VOLUME -gt 25 ]]; then + ICON="" # Low volume + COLOR=$YELLOW + elif [[ $VOLUME -gt 0 ]]; then + ICON="" # Very low volume + COLOR=$ORANGE + else + ICON="" # No volume + COLOR=$RED + fi + LABEL="" # No label since we're not showing labels in the bar +fi + +# Update the volume item +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label="$LABEL" + +# Update popup if it's currently showing +if [ "$(sketchybar --query volume | jq -r '.popup.drawing')" = "on" ]; then + # Update the slider bar + SLIDER_BAR="" + FILLED_SEGMENTS=$((VOLUME / 2)) + + for i in {1..50}; do + if [ $i -le $FILLED_SEGMENTS ]; then + SLIDER_BAR="${SLIDER_BAR}█" + else + SLIDER_BAR="${SLIDER_BAR}▒" + fi + done + + # Update mute button + if [[ $MUTED == "true" ]]; then + MUTE_ICON="" + MUTE_COLOR=$RED + else + MUTE_ICON="" + MUTE_COLOR=$GREEN + fi + + sketchybar --set volume.mute icon="$MUTE_ICON" icon.color="$MUTE_COLOR" + sketchybar --set volume.slider icon="$SLIDER_BAR" + sketchybar --set volume.percent icon="$VOLUME%" +fi diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/volume_click.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/volume_click.sh new file mode 100755 index 0000000..82badb8 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/volume_click.sh @@ -0,0 +1,82 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Toggle popup +sketchybar --set volume popup.drawing=toggle + +# Get current volume and mute status +VOLUME=$(osascript -e "output volume of (get volume settings)" 2>/dev/null || echo "50") +MUTED=$(osascript -e "output muted of (get volume settings)" 2>/dev/null || echo "false") + +# Add mute toggle +if [ "$MUTED" = "true" ]; then + MUTE_ICON="" + MUTE_COLOR=$RED +else + MUTE_ICON="" + MUTE_COLOR=$GREEN +fi + +sketchybar --add item volume.mute popup.volume \ + --set volume.mute icon="$MUTE_ICON" \ + icon.color="$MUTE_COLOR" \ + label.drawing=off \ + background.drawing=off \ + padding_left=8 \ + padding_right=2 \ + click_script="osascript -e 'set volume output muted not (output muted of (get volume settings))'" + +# Add volume down button +sketchybar --add item volume.down popup.volume \ + --set volume.down icon="−" \ + icon.color=$WHITE \ + icon.font="SF Pro:Medium:14.0" \ + label.drawing=off \ + background.drawing=off \ + padding_left=2 \ + padding_right=2 \ + click_script="osascript -e 'set volume output volume ((output volume of (get volume settings)) - 5)'" + +# Create compact slider bar with 50 segments +SLIDER_BAR="" +FILLED_SEGMENTS=$((VOLUME / 2)) + +for i in {1..50}; do + if [ $i -le $FILLED_SEGMENTS ]; then + SLIDER_BAR="${SLIDER_BAR}█" + else + SLIDER_BAR="${SLIDER_BAR}▒" + fi +done + +sketchybar --add item volume.slider popup.volume \ + --set volume.slider icon="$SLIDER_BAR" \ + icon.color=$ACCENT_PRIMARY \ + icon.font="SF Pro:Regular:2.0" \ + label.drawing=off \ + background.drawing=off \ + padding_left=2 \ + padding_right=2 \ + click_script="osascript -e 'set volume output volume 50'" + +# Add volume up button +sketchybar --add item volume.up popup.volume \ + --set volume.up icon="+" \ + icon.color=$WHITE \ + icon.font="SF Pro:Medium:14.0" \ + label.drawing=off \ + background.drawing=off \ + padding_left=2 \ + padding_right=2 \ + click_script="osascript -e 'set volume output volume ((output volume of (get volume settings)) + 5)'" + +# Add volume percentage +sketchybar --add item volume.percent popup.volume \ + --set volume.percent icon="$VOLUME%" \ + icon.color=$WHITE \ + icon.font="SF Pro:Medium:9.0" \ + label.drawing=off \ + background.drawing=off \ + padding_left=2 diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/weather.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/weather.sh new file mode 100755 index 0000000..b96bab8 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/weather.sh @@ -0,0 +1,52 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Cache file for weather data +CACHE_FILE="/tmp/sketchybar_weather_cache" +CACHE_DURATION=1800 # 30 minutes + +# Function to get weather data +get_weather() { + # You can replace this with your preferred weather API + # For now, using a simple placeholder + local location="San Francisco" # Change to your location + + # Try to get weather from wttr.in (simple text-based weather) + local weather_data=$(curl -s "wttr.in/$location?format=3" 2>/dev/null) + + if [ -n "$weather_data" ]; then + echo "$weather_data" + else + echo "Weather unavailable" + fi +} + +# Check if cache is valid +if [ -f "$CACHE_FILE" ]; then + cache_time=$(stat -f %m "$CACHE_FILE" 2>/dev/null || echo 0) + current_time=$(date +%s) + + if [ $((current_time - cache_time)) -lt $CACHE_DURATION ]; then + weather=$(cat "$CACHE_FILE") + else + weather=$(get_weather) + echo "$weather" > "$CACHE_FILE" + fi +else + weather=$(get_weather) + echo "$weather" > "$CACHE_FILE" +fi + +# Extract temperature and condition +if [[ "$weather" =~ ([0-9.-]+°[CF]) ]]; then + temp="${BASH_REMATCH[1]}" + sketchybar --set "$NAME" label="$temp" \ + icon.color=$BLUE \ + label.color=$WHITE +else + sketchybar --set "$NAME" label="N/A" \ + icon.color=$GREY \ + label.color=$GREY +fi diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/wifi.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/wifi.sh new file mode 100755 index 0000000..408fd00 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/wifi.sh @@ -0,0 +1,53 @@ +#!/usr/bin/env bash + +# Source colors for consistent theming +source "$CONFIG_DIR/colors.sh" + +# Multiple methods to detect WiFi status +WIFI_CONNECTED=false +WIFI_SSID="" + +# Method 1: Check if WiFi interface is up and has IP +WIFI_IP=$(ifconfig en0 2>/dev/null | grep "inet " | awk '{print $2}' | head -1) +if [[ -n "$WIFI_IP" && "$WIFI_IP" != "127.0.0.1" ]]; then + # Method 2: Get network name using networksetup + WIFI_INFO=$(networksetup -getairportnetwork en0 2>/dev/null) + if [[ "$WIFI_INFO" != *"You are not associated"* ]] && [[ "$WIFI_INFO" != *"not found"* ]]; then + WIFI_SSID=$(echo "$WIFI_INFO" | sed 's/Current Wi-Fi Network: //') + WIFI_CONNECTED=true + fi +fi + +# Method 3: Alternative check using system_profiler (slower but more reliable) +if [[ "$WIFI_CONNECTED" == false ]]; then + WIFI_STATUS=$(system_profiler SPAirPortDataType 2>/dev/null | grep -A 1 "Current Network Information:" | grep "^[[:space:]]*[^:]" | head -1 | xargs) + if [[ -n "$WIFI_STATUS" && "$WIFI_STATUS" != "" ]]; then + WIFI_SSID="$WIFI_STATUS" + WIFI_CONNECTED=true + fi +fi + +# Method 4: Check using scutil (most reliable) +if [[ "$WIFI_CONNECTED" == false ]]; then + WIFI_CHECK=$(scutil --nc list | grep Connected | head -1) + if [[ -n "$WIFI_CHECK" ]]; then + WIFI_CONNECTED=true + WIFI_SSID="Connected" + fi +fi + +# Set icon and color based on connection status +if [[ "$WIFI_CONNECTED" == true ]]; then + # WiFi is connected - green icon + ICON="" + COLOR=$ACCENT_SECONDARY # Green +else + # WiFi is disconnected - gray icon + ICON="" + COLOR=$GREY +fi + +# Update the WiFi item - icon only, no label +sketchybar --set "$NAME" icon="$ICON" \ + icon.color="$COLOR" \ + label.drawing=off diff --git a/mac/.config/sketchybar.mon/sketchybar/plugins/zen.sh b/mac/.config/sketchybar.mon/sketchybar/plugins/zen.sh new file mode 100755 index 0000000..38f2291 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/plugins/zen.sh @@ -0,0 +1,43 @@ +#!/bin/bash + +zen_on() { + sketchybar --set wifi drawing=off \ + --set apple.logo drawing=off \ + --set '/cpu.*/' drawing=off \ + --set calendar icon.drawing=off \ + --set separator drawing=off \ + --set front_app drawing=off \ + --set volume_icon drawing=off \ + --set spotify.anchor drawing=off \ + --set spotify.play updates=off \ + --set brew drawing=off \ + --set volume drawing=off \ + --set github.bell drawing=off +} + +zen_off() { + sketchybar --set wifi drawing=on \ + --set apple.logo drawing=on \ + --set '/cpu.*/' drawing=on \ + --set calendar icon.drawing=on \ + --set separator drawing=on \ + --set front_app drawing=on \ + --set volume_icon drawing=on \ + --set spotify.play updates=on \ + --set brew drawing=on \ + --set volume drawing=on \ + --set github.bell drawing=on +} + +if [ "$1" = "on" ]; then + zen_on +elif [ "$1" = "off" ]; then + zen_off +else + if [ "$(sketchybar --query apple.logo | jq -r ".geometry.drawing")" = "on" ]; then + zen_on + else + zen_off + fi +fi + diff --git a/mac/.config/sketchybar.mon/sketchybar/reference.md b/mac/.config/sketchybar.mon/sketchybar/reference.md new file mode 100644 index 0000000..9ba5418 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/reference.md @@ -0,0 +1,3 @@ +# Reference link +https://github.com/hbthen3rd/dotfiles/tree/master/.config/sketchybar + diff --git a/mac/.config/sketchybar.mon/sketchybar/restart.sh b/mac/.config/sketchybar.mon/sketchybar/restart.sh new file mode 100755 index 0000000..3cfcbaa --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/restart.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env bash + +# Kill existing sketchybar instances +killall sketchybar + +# Wait a moment for processes to terminate +sleep 1 + +# Start sketchybar with new configuration +sketchybar --config "$HOME/.config/sketchybar/sketchybarrc" + +echo "SketchyBar restarted with new aesthetic configuration!" +echo "✨ Features included:" +echo " • Modern Catppuccin color scheme" +echo " • Beautiful aerospace workspace tiles" +echo " • Active workspace highlighting" +echo " • Enhanced battery, volume, and weather widgets" +echo " • Smooth animations and transitions" +echo " • Clean, minimal design"
\ No newline at end of file diff --git a/mac/.config/sketchybar.mon/sketchybar/sketchybarrc b/mac/.config/sketchybar.mon/sketchybar/sketchybarrc new file mode 100755 index 0000000..1169de5 --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybar/sketchybarrc @@ -0,0 +1,287 @@ +#!/bin/bash + +# Modern aesthetic sketchybar configuration with aerospace integration +# Colors and icons are defined in separate files for better organization + +source "$CONFIG_DIR/colors.sh" +source "$CONFIG_DIR/icons.sh" + +PLUGIN_DIR="$CONFIG_DIR/plugins" + +##### Bar Appearance ##### +sketchybar --bar position=top height=42 \ + color=$BAR_COLOR \ + border_width=0 \ + corner_radius=0 \ + margin=0 \ + blur_radius=0 \ + padding_left=16 \ + padding_right=16 \ + shadow=off \ + sticky=on \ + topmost=window + +##### Changing Defaults ##### +default=( + updates=when_shown + icon.font="SF Pro:Semibold:15.0" + icon.color=$ICON_COLOR + icon.padding_left=6 + icon.padding_right=6 + label.font="SF Pro:Semibold:13.0" + label.color=$LABEL_COLOR + label.padding_left=6 + label.padding_right=6 + padding_left=8 + padding_right=8 + background.height=26 + background.corner_radius=6 + background.border_width=1 + background.border_color=$BACKGROUND_2 + popup.background.border_width=2 + popup.background.corner_radius=6 + popup.background.border_color=$POPUP_BORDER_COLOR + popup.background.color=$POPUP_BACKGROUND_COLOR +) + +sketchybar --default "${default[@]}" + +##### Left Side Items ##### + +# Apple Logo +sketchybar --add item apple.logo left \ + --set apple.logo icon=$APPLE \ + icon.font="SF Pro:Black:16.0" \ + icon.color=$ACCENT_SECONDARY \ + padding_right=12 \ + padding_left=4 \ + label.drawing=off \ + click_script="$PLUGIN_DIR/apple.sh" + +# Aerospace Display-Aware Workspaces +sketchybar --add event aerospace_workspace_change + +# Monitor 1 Workspace Indicator (Primary - Built-in Display) +sketchybar --add item monitor_1_workspace left \ + --subscribe monitor_1_workspace aerospace_workspace_change \ + --set monitor_1_workspace \ + icon="M1:4" \ + icon.font="SF Pro:Medium:12.0" \ + icon.color=$GREY \ + icon.padding_left=8 \ + icon.padding_right=8 \ + label.drawing=off \ + padding_left=4 \ + padding_right=4 \ + background.color=$BACKGROUND_1 \ + background.corner_radius=6 \ + background.height=26 \ + background.drawing=on \ + script="$PLUGIN_DIR/aerospace_display.sh" + +# Monitor 2 Workspace Indicator (External - MAG 274UPF E2) +sketchybar --add item monitor_2_workspace left \ + --subscribe monitor_2_workspace aerospace_workspace_change \ + --set monitor_2_workspace \ + icon="M2:1" \ + icon.font="SF Pro:Medium:12.0" \ + icon.color=$GREY \ + icon.padding_left=8 \ + icon.padding_right=8 \ + label.drawing=off \ + padding_left=4 \ + padding_right=4 \ + background.color=$BACKGROUND_1 \ + background.corner_radius=6 \ + background.height=26 \ + background.drawing=on \ + script="$PLUGIN_DIR/aerospace_display.sh" + +# Monitor Connection Watcher (detects when monitors are connected/disconnected) +sketchybar --add item monitor_watcher left \ + --set monitor_watcher \ + drawing=off \ + update_freq=5 \ + script="$PLUGIN_DIR/monitor_watcher.sh" + +# Separator +sketchybar --add item separator left \ + --set separator icon="" \ + icon.font="SF Pro:Regular:16.0" \ + icon.color=$ACCENT_TERTIARY \ + padding_left=12 \ + padding_right=8 \ + label.drawing=off + +# Front App +sketchybar --add item front_app left \ + --set front_app icon.drawing=on \ + icon.font="SF Pro:Semibold:15.0" \ + icon.color=$ACCENT_QUATERNARY \ + icon.padding_left=6 \ + icon.padding_right=8 \ + label.font="SF Pro:Medium:13.0" \ + label.color=$WHITE \ + label.padding_left=4 \ + label.padding_right=8 \ + padding_left=8 \ + padding_right=8 \ + script="$PLUGIN_DIR/front_app.sh" \ + --subscribe front_app front_app_switched + +##### Right Side Items ##### + + + +# Calendar Events +sketchybar --add item calendar right \ + --set calendar icon.font="SF Pro:Semibold:12.0" \ + icon.padding_left=8 \ + icon.padding_right=6 \ + label.font="SF Pro:Medium:10.0" \ + label.padding_left=4 \ + label.padding_right=8 \ + label.max_chars=25 \ + update_freq=300 \ + script="$PLUGIN_DIR/calendar.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + background.height=26 \ + padding_left=4 \ + padding_right=4 + +# Now Playing +sketchybar --add item now_playing right \ + --set now_playing icon.font="SF Pro:Semibold:15.0" \ + icon.padding_left=8 \ + icon.padding_right=6 \ + label.font="SF Pro:Medium:12.0" \ + label.padding_left=4 \ + label.padding_right=8 \ + update_freq=2 \ + script="$PLUGIN_DIR/now_playing.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + drawing=off \ + padding_left=4 \ + padding_right=4 + + + +# WiFi Status +sketchybar --add item wifi right \ + --set wifi icon.font="SF Pro:Semibold:15.0" \ + icon.padding_left=8 \ + icon.padding_right=8 \ + label.drawing=off \ + update_freq=10 \ + script="$PLUGIN_DIR/wifi.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + padding_left=4 \ + padding_right=4 + +# Bluetooth Status +sketchybar --add item bluetooth right \ + --set bluetooth icon.font="SF Pro:Semibold:15.0" \ + icon.padding_left=9 \ + icon.padding_right=9 \ + label.drawing=off \ + update_freq=10 \ + script="$PLUGIN_DIR/bluetooth.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + padding_left=4 \ + padding_right=4 + +# Clock +sketchybar --add item clock right \ + --set clock icon="" \ + icon.font="SF Pro:Semibold:15.0" \ + icon.color=$YELLOW \ + icon.padding_left=8 \ + icon.padding_right=6 \ + label.font="SF Pro:Medium:12.0" \ + label.color=$WHITE \ + label.padding_left=4 \ + label.padding_right=8 \ + update_freq=10 \ + script="$PLUGIN_DIR/clock.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + padding_left=4 \ + padding_right=4 \ + click_script="$PLUGIN_DIR/clock_click.sh" + +# Volume +sketchybar --add item volume right \ + --set volume icon.font="SF Pro:Semibold:15.0" \ + icon.color=$ACCENT_PRIMARY \ + icon.padding_left=10 \ + icon.padding_right=12 \ + label.drawing=off \ + script="$PLUGIN_DIR/volume.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + padding_left=4 \ + padding_right=4 \ + click_script="$PLUGIN_DIR/volume_click.sh" \ + popup.background.border_width=2 \ + popup.background.corner_radius=6 \ + popup.background.border_color=$POPUP_BORDER_COLOR \ + popup.background.color=$POPUP_BACKGROUND_COLOR \ + popup.horizontal=on \ + --subscribe volume volume_change + +# Battery +sketchybar --add item battery right \ + --set battery icon.font="SF Pro:Semibold:15.0" \ + icon.color=$ACCENT_SECONDARY \ + icon.padding_left=8 \ + icon.padding_right=6 \ + label.font="SF Pro:Medium:12.0" \ + label.color=$WHITE \ + label.padding_left=4 \ + label.padding_right=8 \ + update_freq=120 \ + script="$PLUGIN_DIR/battery.sh" \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + padding_left=4 \ + padding_right=4 \ + --subscribe battery system_woke power_source_change + +# Pritunl VPN +sketchybar --add item pritunl right \ + --set pritunl icon="" \ + icon.font="SF Pro:Semibold:13.0" \ + icon.color=$ACCENT_PRIMARY \ + icon.padding_left=8 \ + icon.padding_right=10 \ + label.drawing=off \ + background.color=$BACKGROUND_1 \ + background.drawing=on \ + padding_left=4 \ + padding_right=4 \ + click_script="open -a Pritunl" + + +# Weather +# sketchybar --add item weather right \ +# --set weather icon="" \ +# icon.font="SF Pro:Semibold:15.0" \ +# icon.color=$BLUE \ +# icon.padding_left=8 \ +# icon.padding_right=6 \ +# label.padding_left=4 \ +# label.padding_right=8 \ +# update_freq=1800 \ +# script="$PLUGIN_DIR/weather.sh" \ +# background.color=$BACKGROUND_1 \ +# background.drawing=on \ +# padding_left=4 \ +# padding_right=4 + +##### Finalize Setup ##### +sketchybar --update + diff --git a/mac/.config/sketchybar.mon/sketchybarrc b/mac/.config/sketchybar.mon/sketchybarrc new file mode 100755 index 0000000..96520fc --- /dev/null +++ b/mac/.config/sketchybar.mon/sketchybarrc @@ -0,0 +1,56 @@ +PLUGIN_DIR="$CONFIG_DIR/plugins" +ITEM_DIR="$CONFIG_DIR/items" + +# Load global styles, colors and icons +source "$CONFIG_DIR/globalstyles.sh" + +POPUP_CLICK_SCRIPT="sketchybar --set \$NAME popup.drawing=toggle" +POPUP_OFF="sketchybar --set \$NAME popup.drawing=off" + +# Setting up and starting the helper process +HELPER=git.felix.helper +killall helper +(cd $CONFIG_DIR/helper && make) +$CONFIG_DIR/helper/helper $HELPER >/dev/null 2>&1 & + +# Unload the macOS on screen indicator overlay for volume change +launchctl unload -F /System/Library/LaunchAgents/com.apple.OSDUIHelper.plist >/dev/null 2>&1 & + +sketchybar --bar "${bar[@]}" --default "${item_defaults[@]}" + +# Left +# source "$ITEM_DIR/apple.sh" +# source "$ITEM_DIR/yabai.sh" +source "$ITEM_DIR/spaces.sh" +source "$ITEM_DIR/front_app.sh" + +# Center +# source "$ITEM_DIR/spotify.sh" +# source "$ITEM_DIR/media.sh" +source "$ITEM_DIR/music.sh" + +# Right +# source "$ITEM_DIR/datetime.sh" +# source "$ITEM_DIR/weather.sh" +source "$ITEM_DIR/github.sh" +source "$ITEM_DIR/brew.sh" +# source "$ITEM_DIR/package_monitor.sh" +# source "$ITEM_DIR/wifi.sh" +# source "$ITEM_DIR/battery.sh" +# source "$ITEM_DIR/keyboard.sh" +# source "$ITEM_DIR/mic.sh" +# source "$ITEM_DIR/volume.sh" +source "$ITEM_DIR/kakaotalk.sh" +source "$ITEM_DIR/mail.sh" +# source "$ITEM_DIR/thunderbird.sh" +source "$ITEM_DIR/svim.sh" +source "$ITEM_DIR/messages.sh" +source "$ITEM_DIR/toggle_stats.sh" +source "$ITEM_DIR/separator_right.sh" +source "$ITEM_DIR/disk.sh" +source "$ITEM_DIR/memory.sh" +source "$ITEM_DIR/cpu.sh" +# source "$ITEM_DIR/network.sh" + +sketchybar --hotload on +sketchybar --update |
