summaryrefslogtreecommitdiff
path: root/mac/.config/sketchybar.mon
diff options
context:
space:
mode:
Diffstat (limited to 'mac/.config/sketchybar.mon')
-rwxr-xr-xmac/.config/sketchybar.mon/colors.sh104
-rwxr-xr-xmac/.config/sketchybar.mon/globalstyles.sh132
-rw-r--r--mac/.config/sketchybar.mon/helper/cpu.h122
-rwxr-xr-xmac/.config/sketchybar.mon/helper/helperbin0 -> 34872 bytes
-rw-r--r--mac/.config/sketchybar.mon/helper/helper.c31
-rw-r--r--mac/.config/sketchybar.mon/helper/makefile3
-rw-r--r--mac/.config/sketchybar.mon/helper/sketchybar.h209
-rwxr-xr-xmac/.config/sketchybar.mon/icons.sh70
-rwxr-xr-xmac/.config/sketchybar.mon/items/apple.sh44
-rwxr-xr-xmac/.config/sketchybar.mon/items/battery.sh23
-rwxr-xr-xmac/.config/sketchybar.mon/items/brew.sh39
-rwxr-xr-xmac/.config/sketchybar.mon/items/cpu.sh74
-rwxr-xr-xmac/.config/sketchybar.mon/items/datetime.sh37
-rwxr-xr-xmac/.config/sketchybar.mon/items/disk.sh18
-rwxr-xr-xmac/.config/sketchybar.mon/items/dnd.sh9
-rwxr-xr-xmac/.config/sketchybar.mon/items/front_app.sh13
-rwxr-xr-xmac/.config/sketchybar.mon/items/github.sh37
-rwxr-xr-xmac/.config/sketchybar.mon/items/kakaotalk.sh18
-rwxr-xr-xmac/.config/sketchybar.mon/items/keyboard.sh14
-rwxr-xr-xmac/.config/sketchybar.mon/items/mail.sh19
-rwxr-xr-xmac/.config/sketchybar.mon/items/memory.sh20
-rwxr-xr-xmac/.config/sketchybar.mon/items/messages.sh13
-rwxr-xr-xmac/.config/sketchybar.mon/items/mic.sh5
-rwxr-xr-xmac/.config/sketchybar.mon/items/music.sh36
-rwxr-xr-xmac/.config/sketchybar.mon/items/network.sh40
-rwxr-xr-xmac/.config/sketchybar.mon/items/package_monitor.sh19
-rwxr-xr-xmac/.config/sketchybar.mon/items/separator_right.sh13
-rwxr-xr-xmac/.config/sketchybar.mon/items/spaces.sh56
-rwxr-xr-xmac/.config/sketchybar.mon/items/spotify.sh201
-rwxr-xr-xmac/.config/sketchybar.mon/items/svim.sh14
-rwxr-xr-xmac/.config/sketchybar.mon/items/system.sh53
-rwxr-xr-xmac/.config/sketchybar.mon/items/thunderbird.sh20
-rwxr-xr-xmac/.config/sketchybar.mon/items/toggle_stats.sh11
-rwxr-xr-xmac/.config/sketchybar.mon/items/volume.sh35
-rwxr-xr-xmac/.config/sketchybar.mon/items/weather.sh23
-rwxr-xr-xmac/.config/sketchybar.mon/items/wifi.sh39
-rwxr-xr-xmac/.config/sketchybar.mon/items/yabai.sh21
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/battery.sh85
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/brew.sh104
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/disk.sh29
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/dnd.sh33
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/dndindicator.sh24
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/front_app.sh8
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/github.sh108
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/icon_map.sh486
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/kakaotalk.sh9
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/keyboard.sh13
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/mail.sh9
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/memory.sh49
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/messages.sh7
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/mic.sh9
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/mic_click.sh11
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/music.sh92
-rw-r--r--mac/.config/sketchybar.mon/plugins/music/Cover-Default.pngbin0 -> 79352 bytes
-rw-r--r--mac/.config/sketchybar.mon/plugins/music/Get-Artwork.applescript65
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/network.sh25
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/nextevent.applescript19
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/nextevent.sh55
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/space.py199
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/space.sh62
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/space_windows.sh20
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/spotify.sh147
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/svim.sh30
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/thunderbird.sh9
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/toggle_stats.sh63
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/volume.sh43
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/volume_click.sh57
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/weather.sh191
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/wifi.sh104
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/yabai.sh141
-rwxr-xr-xmac/.config/sketchybar.mon/plugins/zen.sh43
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/ 👽 aerospace-config/.aerospace.toml256
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/LICENSE21
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/colors.sh44
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/helper/cpu.h122
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/helper/helperbin0 -> 34872 bytes
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/helper/helper.c31
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/helper/makefile3
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/helper/sketchybar.h209
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/icons.sh57
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/apple.sh44
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/battery.sh16
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/calendar.sh16
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/cpu.sh53
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/front_app.sh13
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/input_source.sh10
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/spaces.sh81
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/volume.sh43
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/items/weather.sh8
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/aerospace.sh117
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/aerospace_display.sh185
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/apple.sh38
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/battery.sh48
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/bluetooth.sh93
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/calendar.sh117
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/change_windows.sh3
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/clock.sh19
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/clock_click.sh43
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/cpu.sh37
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/front_app.sh104
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/get_input_source.sh13
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/icon_map.sh637
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/monitor_watcher.sh25
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/now_playing.sh77
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/space.sh7
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/space_windows.sh87
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/plugins/test_click.sh3
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/volume.sh77
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/volume_click.sh82
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/weather.sh52
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/wifi.sh53
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/plugins/zen.sh43
-rw-r--r--mac/.config/sketchybar.mon/sketchybar/reference.md3
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/restart.sh19
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybar/sketchybarrc287
-rwxr-xr-xmac/.config/sketchybar.mon/sketchybarrc56
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
new file mode 100755
index 0000000..050cca7
--- /dev/null
+++ b/mac/.config/sketchybar.mon/helper/helper
Binary files differ
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
new file mode 100644
index 0000000..a65c63f
--- /dev/null
+++ b/mac/.config/sketchybar.mon/plugins/music/Cover-Default.png
Binary files differ
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
new file mode 100755
index 0000000..050cca7
--- /dev/null
+++ b/mac/.config/sketchybar.mon/sketchybar/helper/helper
Binary files differ
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