mirror of
https://github.com/basecamp/omarchy.git
synced 2026-02-17 15:25:37 +00:00
Compare commits
2 Commits
remove-rec
...
mtu-probin
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7933b5eae0 | ||
|
|
3e4597b89c |
11
applications/About.desktop
Normal file
11
applications/About.desktop
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=About
|
||||||
|
Comment=System information from Fastfetch
|
||||||
|
Exec=alacritty -o "font.size=9" --class=About --title=About -e bash -c 'fastfetch; read -n 1 -s'
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
Icon=Arch
|
||||||
|
Categories=GTK;
|
||||||
|
StartupNotify=false
|
||||||
|
|
||||||
11
applications/Activity.desktop
Normal file
11
applications/Activity.desktop
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=Activity
|
||||||
|
Comment=System activity from btop
|
||||||
|
Exec=alacritty --class=Activity --title=Activity -e btop
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
Icon=Activity
|
||||||
|
Categories=GTK;
|
||||||
|
StartupNotify=false
|
||||||
|
|
||||||
11
applications/Docker.desktop
Normal file
11
applications/Docker.desktop
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=Docker
|
||||||
|
Comment=Manage Docker containers with LazyDocker
|
||||||
|
Exec=alacritty --class=Docker --title=Docker -e lazydocker
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
Icon=Docker
|
||||||
|
Categories=GTK;
|
||||||
|
StartupNotify=false
|
||||||
|
|
||||||
221
applications/chromium.desktop
Normal file
221
applications/chromium.desktop
Normal file
@@ -0,0 +1,221 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=Chromium
|
||||||
|
# Only KDE 4 seems to use GenericName, so we reuse the KDE strings.
|
||||||
|
# From Ubuntu's language-pack-kde-XX-base packages, version 9.04-20090413.
|
||||||
|
GenericName=Web Browser
|
||||||
|
GenericName[ar]=متصفح الشبكة
|
||||||
|
GenericName[bg]=Уеб браузър
|
||||||
|
GenericName[ca]=Navegador web
|
||||||
|
GenericName[cs]=WWW prohlížeč
|
||||||
|
GenericName[da]=Browser
|
||||||
|
GenericName[de]=Web-Browser
|
||||||
|
GenericName[el]=Περιηγητής ιστού
|
||||||
|
GenericName[en_GB]=Web Browser
|
||||||
|
GenericName[es]=Navegador web
|
||||||
|
GenericName[et]=Veebibrauser
|
||||||
|
GenericName[fi]=WWW-selain
|
||||||
|
GenericName[fr]=Navigateur Web
|
||||||
|
GenericName[gu]=વેબ બ્રાઉઝર
|
||||||
|
GenericName[he]=דפדפן אינטרנט
|
||||||
|
GenericName[hi]=वेब ब्राउज़र
|
||||||
|
GenericName[hu]=Webböngésző
|
||||||
|
GenericName[it]=Browser Web
|
||||||
|
GenericName[ja]=ウェブブラウザ
|
||||||
|
GenericName[kn]=ಜಾಲ ವೀಕ್ಷಕ
|
||||||
|
GenericName[ko]=웹 브라우저
|
||||||
|
GenericName[lt]=Žiniatinklio naršyklė
|
||||||
|
GenericName[lv]=Tīmekļa pārlūks
|
||||||
|
GenericName[ml]=വെബ് ബ്രൌസര്
|
||||||
|
GenericName[mr]=वेब ब्राऊजर
|
||||||
|
GenericName[nb]=Nettleser
|
||||||
|
GenericName[nl]=Webbrowser
|
||||||
|
GenericName[pl]=Przeglądarka WWW
|
||||||
|
GenericName[pt]=Navegador Web
|
||||||
|
GenericName[pt_BR]=Navegador da Internet
|
||||||
|
GenericName[ro]=Navigator de Internet
|
||||||
|
GenericName[ru]=Веб-браузер
|
||||||
|
GenericName[sl]=Spletni brskalnik
|
||||||
|
GenericName[sv]=Webbläsare
|
||||||
|
GenericName[ta]=இணைய உலாவி
|
||||||
|
GenericName[th]=เว็บเบราว์เซอร์
|
||||||
|
GenericName[tr]=Web Tarayıcı
|
||||||
|
GenericName[uk]=Навігатор Тенет
|
||||||
|
GenericName[zh_CN]=网页浏览器
|
||||||
|
GenericName[zh_HK]=網頁瀏覽器
|
||||||
|
GenericName[zh_TW]=網頁瀏覽器
|
||||||
|
# Not translated in KDE, from Epiphany 2.26.1-0ubuntu1.
|
||||||
|
GenericName[bn]=ওয়েব ব্রাউজার
|
||||||
|
GenericName[fil]=Web Browser
|
||||||
|
GenericName[hr]=Web preglednik
|
||||||
|
GenericName[id]=Browser Web
|
||||||
|
GenericName[or]=ଓ୍ବେବ ବ୍ରାଉଜର
|
||||||
|
GenericName[sk]=WWW prehliadač
|
||||||
|
GenericName[sr]=Интернет прегледник
|
||||||
|
GenericName[te]=మహాతల అన్వేషి
|
||||||
|
GenericName[vi]=Bộ duyệt Web
|
||||||
|
# Gnome and KDE 3 uses Comment.
|
||||||
|
Comment=Access the Internet
|
||||||
|
Comment[ar]=الدخول إلى الإنترنت
|
||||||
|
Comment[bg]=Достъп до интернет
|
||||||
|
Comment[bn]=ইন্টারনেটটি অ্যাক্সেস করুন
|
||||||
|
Comment[ca]=Accedeix a Internet
|
||||||
|
Comment[cs]=Přístup k internetu
|
||||||
|
Comment[da]=Få adgang til internettet
|
||||||
|
Comment[de]=Internetzugriff
|
||||||
|
Comment[el]=Πρόσβαση στο Διαδίκτυο
|
||||||
|
Comment[en_GB]=Access the Internet
|
||||||
|
Comment[es]=Accede a Internet.
|
||||||
|
Comment[et]=Pääs Internetti
|
||||||
|
Comment[fi]=Käytä internetiä
|
||||||
|
Comment[fil]=I-access ang Internet
|
||||||
|
Comment[fr]=Accéder à Internet
|
||||||
|
Comment[gu]=ઇંટરનેટ ઍક્સેસ કરો
|
||||||
|
Comment[he]=גישה אל האינטרנט
|
||||||
|
Comment[hi]=इंटरनेट तक पहुंच स्थापित करें
|
||||||
|
Comment[hr]=Pristup Internetu
|
||||||
|
Comment[hu]=Internetelérés
|
||||||
|
Comment[id]=Akses Internet
|
||||||
|
Comment[it]=Accesso a Internet
|
||||||
|
Comment[ja]=インターネットにアクセス
|
||||||
|
Comment[kn]=ಇಂಟರ್ನೆಟ್ ಅನ್ನು ಪ್ರವೇಶಿಸಿ
|
||||||
|
Comment[ko]=인터넷 연결
|
||||||
|
Comment[lt]=Interneto prieiga
|
||||||
|
Comment[lv]=Piekļūt internetam
|
||||||
|
Comment[ml]=ഇന്റര്നെറ്റ് ആക്സസ് ചെയ്യുക
|
||||||
|
Comment[mr]=इंटरनेटमध्ये प्रवेश करा
|
||||||
|
Comment[nb]=Gå til Internett
|
||||||
|
Comment[nl]=Verbinding maken met internet
|
||||||
|
Comment[or]=ଇଣ୍ଟର୍ନେଟ୍ ପ୍ରବେଶ କରନ୍ତୁ
|
||||||
|
Comment[pl]=Skorzystaj z internetu
|
||||||
|
Comment[pt]=Aceder à Internet
|
||||||
|
Comment[pt_BR]=Acessar a internet
|
||||||
|
Comment[ro]=Accesaţi Internetul
|
||||||
|
Comment[ru]=Доступ в Интернет
|
||||||
|
Comment[sk]=Prístup do siete Internet
|
||||||
|
Comment[sl]=Dostop do interneta
|
||||||
|
Comment[sr]=Приступите Интернету
|
||||||
|
Comment[sv]=Gå ut på Internet
|
||||||
|
Comment[ta]=இணையத்தை அணுகுதல்
|
||||||
|
Comment[te]=ఇంటర్నెట్ను ఆక్సెస్ చెయ్యండి
|
||||||
|
Comment[th]=เข้าถึงอินเทอร์เน็ต
|
||||||
|
Comment[tr]=İnternet'e erişin
|
||||||
|
Comment[uk]=Доступ до Інтернету
|
||||||
|
Comment[vi]=Truy cập Internet
|
||||||
|
Comment[zh_CN]=访问互联网
|
||||||
|
Comment[zh_HK]=連線到網際網路
|
||||||
|
Comment[zh_TW]=連線到網際網路
|
||||||
|
Exec=/usr/bin/chromium --ozone-platform=wayland %U
|
||||||
|
StartupNotify=true
|
||||||
|
Terminal=false
|
||||||
|
Icon=chromium
|
||||||
|
Type=Application
|
||||||
|
Categories=Network;WebBrowser;
|
||||||
|
MimeType=application/pdf;application/rdf+xml;application/rss+xml;application/xhtml+xml;application/xhtml_xml;application/xml;image/gif;image/jpeg;image/png;image/webp;text/html;text/xml;x-scheme-handler/http;x-scheme-handler/https;
|
||||||
|
Actions=new-window;new-private-window;
|
||||||
|
|
||||||
|
[Desktop Action new-window]
|
||||||
|
Name=New Window
|
||||||
|
Name[am]=አዲስ መስኮት
|
||||||
|
Name[ar]=نافذة جديدة
|
||||||
|
Name[bg]=Нов прозорец
|
||||||
|
Name[bn]=নতুন উইন্ডো
|
||||||
|
Name[ca]=Finestra nova
|
||||||
|
Name[cs]=Nové okno
|
||||||
|
Name[da]=Nyt vindue
|
||||||
|
Name[de]=Neues Fenster
|
||||||
|
Name[el]=Νέο Παράθυρο
|
||||||
|
Name[en_GB]=New Window
|
||||||
|
Name[es]=Nueva ventana
|
||||||
|
Name[et]=Uus aken
|
||||||
|
Name[fa]=پنجره جدید
|
||||||
|
Name[fi]=Uusi ikkuna
|
||||||
|
Name[fil]=New Window
|
||||||
|
Name[fr]=Nouvelle fenêtre
|
||||||
|
Name[gu]=નવી વિંડો
|
||||||
|
Name[hi]=नई विंडो
|
||||||
|
Name[hr]=Novi prozor
|
||||||
|
Name[hu]=Új ablak
|
||||||
|
Name[id]=Jendela Baru
|
||||||
|
Name[it]=Nuova finestra
|
||||||
|
Name[iw]=חלון חדש
|
||||||
|
Name[ja]=新規ウインドウ
|
||||||
|
Name[kn]=ಹೊಸ ವಿಂಡೊ
|
||||||
|
Name[ko]=새 창
|
||||||
|
Name[lt]=Naujas langas
|
||||||
|
Name[lv]=Jauns logs
|
||||||
|
Name[ml]=പുതിയ വിന്ഡോ
|
||||||
|
Name[mr]=नवीन विंडो
|
||||||
|
Name[nl]=Nieuw venster
|
||||||
|
Name[no]=Nytt vindu
|
||||||
|
Name[pl]=Nowe okno
|
||||||
|
Name[pt]=Nova janela
|
||||||
|
Name[pt_BR]=Nova janela
|
||||||
|
Name[ro]=Fereastră nouă
|
||||||
|
Name[ru]=Новое окно
|
||||||
|
Name[sk]=Nové okno
|
||||||
|
Name[sl]=Novo okno
|
||||||
|
Name[sr]=Нови прозор
|
||||||
|
Name[sv]=Nytt fönster
|
||||||
|
Name[sw]=Dirisha Jipya
|
||||||
|
Name[ta]=புதிய சாளரம்
|
||||||
|
Name[te]=క్రొత్త విండో
|
||||||
|
Name[th]=หน้าต่างใหม่
|
||||||
|
Name[tr]=Yeni Pencere
|
||||||
|
Name[uk]=Нове вікно
|
||||||
|
Name[vi]=Cửa sổ Mới
|
||||||
|
Name[zh_CN]=新建窗口
|
||||||
|
Name[zh_TW]=開新視窗
|
||||||
|
Exec=/usr/bin/chromium --ozone-platform=wayland --new-window
|
||||||
|
|
||||||
|
[Desktop Action new-private-window]
|
||||||
|
Name=New Incognito Window
|
||||||
|
Name[ar]=نافذة جديدة للتصفح المتخفي
|
||||||
|
Name[bg]=Нов прозорец „инкогнито“
|
||||||
|
Name[bn]=নতুন ছদ্মবেশী উইন্ডো
|
||||||
|
Name[ca]=Finestra d'incògnit nova
|
||||||
|
Name[cs]=Nové anonymní okno
|
||||||
|
Name[da]=Nyt inkognitovindue
|
||||||
|
Name[de]=Neues Inkognito-Fenster
|
||||||
|
Name[el]=Νέο παράθυρο για ανώνυμη περιήγηση
|
||||||
|
Name[en_GB]=New Incognito window
|
||||||
|
Name[es]=Nueva ventana de incógnito
|
||||||
|
Name[et]=Uus inkognito aken
|
||||||
|
Name[fa]=پنجره جدید حالت ناشناس
|
||||||
|
Name[fi]=Uusi incognito-ikkuna
|
||||||
|
Name[fil]=Bagong Incognito window
|
||||||
|
Name[fr]=Nouvelle fenêtre de navigation privée
|
||||||
|
Name[gu]=નવી છુપી વિંડો
|
||||||
|
Name[hi]=नई गुप्त विंडो
|
||||||
|
Name[hr]=Novi anoniman prozor
|
||||||
|
Name[hu]=Új Inkognitóablak
|
||||||
|
Name[id]=Jendela Penyamaran baru
|
||||||
|
Name[it]=Nuova finestra di navigazione in incognito
|
||||||
|
Name[iw]=חלון חדש לגלישה בסתר
|
||||||
|
Name[ja]=新しいシークレット ウィンドウ
|
||||||
|
Name[kn]=ಹೊಸ ಅಜ್ಞಾತ ವಿಂಡೋ
|
||||||
|
Name[ko]=새 시크릿 창
|
||||||
|
Name[lt]=Naujas inkognito langas
|
||||||
|
Name[lv]=Jauns inkognito režīma logs
|
||||||
|
Name[ml]=പുതിയ വേഷ പ്രച്ഛന്ന വിന്ഡോ
|
||||||
|
Name[mr]=नवीन गुप्त विंडो
|
||||||
|
Name[nl]=Nieuw incognitovenster
|
||||||
|
Name[no]=Nytt inkognitovindu
|
||||||
|
Name[pl]=Nowe okno incognito
|
||||||
|
Name[pt]=Nova janela de navegação anónima
|
||||||
|
Name[pt_BR]=Nova janela anônima
|
||||||
|
Name[ro]=Fereastră nouă incognito
|
||||||
|
Name[ru]=Новое окно в режиме инкогнито
|
||||||
|
Name[sk]=Nové okno inkognito
|
||||||
|
Name[sl]=Novo okno brez beleženja zgodovine
|
||||||
|
Name[sr]=Нови прозор за прегледање без архивирања
|
||||||
|
Name[sv]=Nytt inkognitofönster
|
||||||
|
Name[ta]=புதிய மறைநிலைச் சாளரம்
|
||||||
|
Name[te]=క్రొత్త అజ్ఞాత విండో
|
||||||
|
Name[th]=หน้าต่างใหม่ที่ไม่ระบุตัวตน
|
||||||
|
Name[tr]=Yeni Gizli pencere
|
||||||
|
Name[uk]=Нове вікно в режимі анонімного перегляду
|
||||||
|
Name[vi]=Cửa sổ ẩn danh mới
|
||||||
|
Name[zh_CN]=新建隐身窗口
|
||||||
|
Name[zh_TW]=新增無痕式視窗
|
||||||
|
Exec=/usr/bin/chromium --ozone-platform=wayland --new-window --incognito
|
||||||
BIN
applications/icons/Activity.png
Normal file
BIN
applications/icons/Activity.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 38 KiB |
BIN
applications/icons/Arch.png
Normal file
BIN
applications/icons/Arch.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 19 KiB |
BIN
applications/icons/Docker.png
Normal file
BIN
applications/icons/Docker.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 21 KiB |
7
applications/wiremix.desktop
Normal file
7
applications/wiremix.desktop
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Name=Audio Settings
|
||||||
|
Comment=Using Wiremix
|
||||||
|
Exec=alacritty --class=Wiremix --title=Wiremix -e wiremix
|
||||||
|
Icon=audio-headphones
|
||||||
|
Type=Application
|
||||||
|
Terminal=false
|
||||||
12
applications/xtras/Zoom.desktop
Normal file
12
applications/xtras/Zoom.desktop
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Name=Zoom
|
||||||
|
Comment=Zoom Video Conference
|
||||||
|
Exec=env QT_SCALE_FACTOR=2 /usr/bin/zoom %U
|
||||||
|
Icon=Zoom
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
Encoding=UTF-8
|
||||||
|
Categories=Network;Application;
|
||||||
|
StartupWMClass=zoom
|
||||||
|
MimeType=x-scheme-handler/zoommtg;x-scheme-handler/zoomus;x-scheme-handler/tel;x-scheme-handler/callto;x-scheme-handler/zoomphonecall;x-scheme-handler/zoomphonesms;x-scheme-handler/zoomcontactcentercall;application/x-zoom
|
||||||
|
X-KDE-Protocols=zoommtg;zoomus;tel;callto;zoomphonecall;zoomphonesms;zoomcontactcentercall;
|
||||||
@@ -1,19 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Find all the audio sinks but exit if there are none
|
|
||||||
sinks=($(wpctl status | sed -n '/Sinks:/,/Sources:/p' | grep -E '^\s*│\s+\*?\s*[0-9]+\.' | sed -E 's/^[^0-9]*([0-9]+)\..*/\1/'))
|
|
||||||
[ ${#sinks[@]} -eq 0 ] && exit 1
|
|
||||||
|
|
||||||
# Find current audio sink
|
|
||||||
current=$(wpctl status | sed -n '/Sinks:/,/Sources:/p' | grep '^\s*│\s*\*' | sed -E 's/^[^0-9]*([0-9]+)\..*/\1/')
|
|
||||||
|
|
||||||
# Find the next sink (looping around in the list)
|
|
||||||
for i in "${!sinks[@]}"; do
|
|
||||||
[ "${sinks[$i]}" = "$current" ] && next=${sinks[$(((i + 1) % ${#sinks[@]}))]}
|
|
||||||
done
|
|
||||||
next=${next:-${sinks[0]}}
|
|
||||||
|
|
||||||
# Set the next sink and ensure it's not muted
|
|
||||||
wpctl set-default "$next"
|
|
||||||
wpctl set-mute "$next" 0
|
|
||||||
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Close all open windows
|
|
||||||
hyprctl clients -j | \
|
|
||||||
jq -r ".[].address" | \
|
|
||||||
xargs -I{} hyprctl dispatch closewindow address:{}
|
|
||||||
|
|
||||||
# Move to first workspace
|
|
||||||
hyprctl dispatch workspace 1
|
|
||||||
@@ -13,7 +13,7 @@ screenrecording() {
|
|||||||
notify-send "Screen recording starting..." -t 1000
|
notify-send "Screen recording starting..." -t 1000
|
||||||
sleep 1
|
sleep 1
|
||||||
|
|
||||||
if lspci | grep -Eqi 'nvidia|intel.*graphics'; then
|
if lspci | grep -qi 'nvidia'; then
|
||||||
wf-recorder -f "$filename" -c libx264 -p crf=23 -p preset=medium -p movflags=+faststart "$@"
|
wf-recorder -f "$filename" -c libx264 -p crf=23 -p preset=medium -p movflags=+faststart "$@"
|
||||||
else
|
else
|
||||||
wl-screenrec -f "$filename" --ffmpeg-encoder-options="-c:v libx264 -crf 23 -preset medium -movflags +faststart" "$@"
|
wl-screenrec -f "$filename" --ffmpeg-encoder-options="-c:v libx264 -crf 23 -preset medium -movflags +faststart" "$@"
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if pgrep -x wl-screenrec >/dev/null || pgrep -x wf-recorder >/dev/null; then
|
|
||||||
pkill -x wl-screenrec
|
|
||||||
pkill -x wf-recorder
|
|
||||||
notify-send "Screen recording stopped" -t 2000
|
|
||||||
fi
|
|
||||||
@@ -3,13 +3,13 @@
|
|||||||
if command -v tte &>/dev/null; then
|
if command -v tte &>/dev/null; then
|
||||||
while true; do
|
while true; do
|
||||||
effect=$(tte 2>&1 | grep -oP '{\K[^}]+' | tr ',' ' ' | tr ' ' '\n' | sed -n '/^beams$/,$p' | sort -u | shuf -n1)
|
effect=$(tte 2>&1 | grep -oP '{\K[^}]+' | tr ',' ' ' | tr ' ' '\n' | sed -n '/^beams$/,$p' | sort -u | shuf -n1)
|
||||||
tte -i ~/.config/omarchy/branding/screensaver.txt \
|
tte -i ~/.local/share/omarchy/logo.txt \
|
||||||
--frame-rate 240 --canvas-width 0 --canvas-height $(($(tput lines) - 2)) --anchor-canvas c --anchor-text c \
|
--frame-rate 240 --canvas-width 0 --canvas-height $(($(tput lines) - 2)) --anchor-canvas c --anchor-text c \
|
||||||
"$effect" &
|
"$effect" &
|
||||||
|
|
||||||
while pgrep -x tte >/dev/null; do
|
while pgrep tte >/dev/null; do
|
||||||
if read -n 1 -t 0.01; then
|
if read -n 1 -t 0.01; then
|
||||||
pkill -x tte 2>/dev/null
|
pkill tte 2>/dev/null
|
||||||
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Go from current active terminal to its child shell process and run cwd there
|
|
||||||
terminal_pid=$(hyprctl activewindow | awk '/pid:/ {print $2}')
|
|
||||||
shell_pid=$(pgrep -P "$terminal_pid" | head -n1)
|
|
||||||
|
|
||||||
if [[ -n $shell_pid ]]; then
|
|
||||||
readlink -f "/proc/$shell_pid/cwd" 2>/dev/null
|
|
||||||
else
|
|
||||||
echo "$HOME"
|
|
||||||
fi
|
|
||||||
@@ -2,5 +2,4 @@
|
|||||||
|
|
||||||
sudo tzupdate
|
sudo tzupdate
|
||||||
new_timezone=$(timedatectl show -p Timezone --value)
|
new_timezone=$(timedatectl show -p Timezone --value)
|
||||||
omarchy-restart-waybar
|
|
||||||
notify-send "Timezone has been set to $new_timezone"
|
notify-send "Timezone has been set to $new_timezone"
|
||||||
|
|||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if ! curl -s --connect-timeout 10 --head -A "omarchy-update" -o /dev/null "https://aur.archlinux.org/"; then
|
|
||||||
gum spin --spinner "globe" --title "The AUR package repository is currently unavailable, please try again later" -- sleep 2 && exit 1
|
|
||||||
fi
|
|
||||||
@@ -5,8 +5,8 @@ font_name="$1"
|
|||||||
if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
||||||
if fc-list | grep -iq "$font_name"; then
|
if fc-list | grep -iq "$font_name"; then
|
||||||
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
||||||
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/waybar/style.css
|
sed -i "s/font-family: .*/font-family: $font_name;/g" ~/.config/waybar/style.css
|
||||||
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/swayosd/style.css
|
sed -i "s/font-family: .*/font-family: $font_name;/g" ~/.config/swayosd/style.css
|
||||||
xmlstarlet ed -L \
|
xmlstarlet ed -L \
|
||||||
-u '//match[@target="pattern"][test/string="monospace"]/edit[@name="family"]/string' \
|
-u '//match[@target="pattern"][test/string="monospace"]/edit[@name="family"]/string' \
|
||||||
-v "$font_name" \
|
-v "$font_name" \
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [[ -z "$1" ]]; then
|
if [[ -z "$1" ]]; then
|
||||||
echo "Usage: omarchy-install-dev-env <ruby|node|bun|go|laravel|symfony|php|python|elixir|phoenix|rust|java|ocaml|dotnet>" >&2
|
echo "Usage: omarchy-instal-dev-env <ruby|node|bun|go|laravel|symfony|php|python|elixir|rust|java|ocaml|dotnet>" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -77,7 +77,7 @@ python)
|
|||||||
echo -e "Installing Python...\n"
|
echo -e "Installing Python...\n"
|
||||||
mise use --global python@latest
|
mise use --global python@latest
|
||||||
echo -e "\nInstalling uv...\n"
|
echo -e "\nInstalling uv...\n"
|
||||||
curl -fsSL https://astral.sh/uv/install.sh | sh
|
wget -qO- https://astral.sh/uv/install.sh | sh
|
||||||
;;
|
;;
|
||||||
elixir)
|
elixir)
|
||||||
echo -e "Installing Elixir...\n"
|
echo -e "Installing Elixir...\n"
|
||||||
@@ -85,18 +85,6 @@ elixir)
|
|||||||
mise use --global elixir@latest
|
mise use --global elixir@latest
|
||||||
mise x elixir -- mix local.hex --force
|
mise x elixir -- mix local.hex --force
|
||||||
;;
|
;;
|
||||||
phoenix)
|
|
||||||
echo -e "Installing Phoenix Framework...\n"
|
|
||||||
# Ensure Erlang/Elixir first
|
|
||||||
mise use --global erlang@latest
|
|
||||||
mise use --global elixir@latest
|
|
||||||
# Hex & Rebar
|
|
||||||
mise x elixir -- mix local.hex --force
|
|
||||||
mise x elixir -- mix local.rebar --force
|
|
||||||
# Phoenix project (phx_new)
|
|
||||||
mise x elixir -- mix archive.install hex phx_new --force
|
|
||||||
echo -e "\nYou can now run: mix phx.new my_app"
|
|
||||||
;;
|
|
||||||
rust)
|
rust)
|
||||||
echo -e "Installing Rust...\n"
|
echo -e "Installing Rust...\n"
|
||||||
bash -c "$(curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs)" -- -y
|
bash -c "$(curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs)" -- -y
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
options=("MySQL" "PostgreSQL" "Redis" "MongoDB" "MariaDB")
|
options=("MariaDB" "MySQL" "Redis" "PostgreSQL")
|
||||||
choices=$(printf "%s\n" "${options[@]}" | gum choose --no-limit --header "Select databases (space to select, return to install, esc to cancel)") || main_menu
|
choices=$(printf "%s\n" "${options[@]}" | gum choose --no-limit --header "Select databases (space to select, return to install, esc to cancel)") || main_menu
|
||||||
|
|
||||||
if [[ -n "$choices" ]]; then
|
if [[ -n "$choices" ]]; then
|
||||||
@@ -10,7 +10,6 @@ if [[ -n "$choices" ]]; then
|
|||||||
PostgreSQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:5432:5432" --name=postgres16 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:16 ;;
|
PostgreSQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:5432:5432" --name=postgres16 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:16 ;;
|
||||||
MariaDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mariadb11 -e MARIADB_ROOT_PASSWORD= -e MARIADB_ALLOW_EMPTY_ROOT_PASSWORD=true mariadb:11.8 ;;
|
MariaDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mariadb11 -e MARIADB_ROOT_PASSWORD= -e MARIADB_ALLOW_EMPTY_ROOT_PASSWORD=true mariadb:11.8 ;;
|
||||||
Redis) sudo docker run -d --restart unless-stopped -p "127.0.0.1:6379:6379" --name=redis redis:7 ;;
|
Redis) sudo docker run -d --restart unless-stopped -p "127.0.0.1:6379:6379" --name=redis redis:7 ;;
|
||||||
MongoDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:27017:27017" --name mongodb -e MONGO_INITDB_ROOT_USERNAME=admin -e MONGO_INITDB_ROOT_PASSWORD=admin123 mongo:noble ;;
|
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,26 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if ! command -v ufw &>/dev/null; then
|
|
||||||
yay -S --noconfirm --needed ufw ufw-docker
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Allow nothing in, everything out
|
|
||||||
sudo ufw default deny incoming
|
|
||||||
sudo ufw default allow outgoing
|
|
||||||
|
|
||||||
# Allow ports for LocalSend
|
|
||||||
sudo ufw allow 53317/udp
|
|
||||||
sudo ufw allow 53317/tcp
|
|
||||||
|
|
||||||
# Allow SSH in
|
|
||||||
sudo ufw allow 22/tcp
|
|
||||||
|
|
||||||
# Allow Docker containers to use DNS on host
|
|
||||||
sudo ufw allow in proto udp from 172.16.0.0/12 to 172.17.0.1 port 53 comment 'allow-docker-dns'
|
|
||||||
|
|
||||||
# Turn on the firewall
|
|
||||||
sudo ufw --force enable
|
|
||||||
|
|
||||||
# Turn on Docker protections
|
|
||||||
sudo ufw-docker install
|
|
||||||
sudo ufw reload
|
|
||||||
@@ -1,13 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
curl -fsSL https://tailscale.com/install.sh | sh
|
curl -fsSL https://tailscale.com/install.sh | sh
|
||||||
curl -fsSL https://neuralink.com/tsui/install.sh | bash
|
|
||||||
|
|
||||||
echo -e "\nStarting Tailscale..."
|
echo -e "\nStarting Tailscale..."
|
||||||
sudo tailscale up --accept-routes
|
sudo tailscale up --accept-routes
|
||||||
|
|
||||||
echo -e "\nAdd tsui to sudoers..."
|
omarchy-webapp-install "Tailscale" "https://login.tailscale.com/admin/machines" https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
||||||
echo "$USER ALL=(ALL) NOPASSWD: $(which tsui)" | sudo tee /etc/sudoers.d/tsui
|
|
||||||
|
|
||||||
omarchy-tui-install "Tailscale" "sudo tsui" float https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
|
||||||
omarchy-webapp-install "Tailscale Admin Console" "https://login.tailscale.com/admin/machines" https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
exec setsid uwsm app -- $(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,/usr}/share/applications/$(xdg-settings get default-web-browser) 2>/dev/null | head -1) ${args[@]} $@
|
|
||||||
@@ -3,11 +3,6 @@
|
|||||||
# Exit early if screensave is already running
|
# Exit early if screensave is already running
|
||||||
pgrep -f "alacritty --class Screensaver" && exit 0
|
pgrep -f "alacritty --class Screensaver" && exit 0
|
||||||
|
|
||||||
# Allow screensaver to be turned off but also force started
|
|
||||||
if [[ -f ~/.local/state/omarchy/toggles/screensaver-off ]] && [[ $1 != "force" ]]; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
focused=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')
|
focused=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')
|
||||||
|
|
||||||
for m in $(hyprctl monitors -j | jq -r '.[] | .name'); do
|
for m in $(hyprctl monitors -j | jq -r '.[] | .name'); do
|
||||||
|
|||||||
@@ -1,10 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
browser=$(xdg-settings get default-web-browser)
|
|
||||||
|
|
||||||
case $browser in
|
|
||||||
google-chrome* | brave-browser* | microsoft-edge* | opera* | vivaldi*) ;;
|
|
||||||
*) browser="chromium.desktop" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exec setsid uwsm app -- $(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,/usr}/share/applications/$browser 2>/dev/null | head -1) --app="$1" "${@:2}"
|
|
||||||
@@ -22,7 +22,7 @@ menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
terminal() {
|
terminal() {
|
||||||
alacritty --class Omarchy -e "$@"
|
alacritty --class Omarchy -e $1
|
||||||
}
|
}
|
||||||
|
|
||||||
present_terminal() {
|
present_terminal() {
|
||||||
@@ -34,6 +34,10 @@ edit_in_nvim() {
|
|||||||
alacritty -e nvim "$1"
|
alacritty -e nvim "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
open_web() {
|
||||||
|
setsid chromium --new-window --app="$1" &
|
||||||
|
}
|
||||||
|
|
||||||
install() {
|
install() {
|
||||||
present_terminal "echo 'Installing $1...'; yay -Sy --noconfirm $2"
|
present_terminal "echo 'Installing $1...'; yay -Sy --noconfirm $2"
|
||||||
}
|
}
|
||||||
@@ -49,22 +53,20 @@ install_font() {
|
|||||||
show_learn_menu() {
|
show_learn_menu() {
|
||||||
case $(menu "Learn" " Keybindings\n Omarchy\n Hyprland\n Arch\n Neovim\n Bash") in
|
case $(menu "Learn" " Keybindings\n Omarchy\n Hyprland\n Arch\n Neovim\n Bash") in
|
||||||
*Keybindings*) omarchy-menu-keybindings ;;
|
*Keybindings*) omarchy-menu-keybindings ;;
|
||||||
*Omarchy*) omarchy-launch-webapp "https://learn.omacom.io/2/the-omarchy-manual" ;;
|
*Omarchy*) open_web "https://manuals.omamix.org/2/the-omarchy-manual" ;;
|
||||||
*Hyprland*) omarchy-launch-webapp "https://wiki.hypr.land/" ;;
|
*Hyprland*) open_web "https://wiki.hypr.land/" ;;
|
||||||
*Arch*) omarchy-launch-webapp "https://wiki.archlinux.org/title/Main_page" ;;
|
*Arch*) open_web "https://wiki.archlinux.org/title/Main_page" ;;
|
||||||
*Bash*) omarchy-launch-webapp "https://devhints.io/bash" ;;
|
*Bash*) open_web "https://devhints.io/bash" ;;
|
||||||
*Neovim*) omarchy-launch-webapp "https://www.lazyvim.org/keymaps" ;;
|
*Neovim*) open_web "https://www.lazyvim.org/keymaps" ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_style_menu() {
|
show_style_menu() {
|
||||||
case $(menu "Style" " Theme\n Font\n Background\n Screensaver\n About") in
|
case $(menu "Style" " Theme\n Font\n Background") in
|
||||||
*Theme*) show_theme_menu ;;
|
*Theme*) show_theme_menu ;;
|
||||||
*Font*) show_font_menu ;;
|
*Font*) show_font_menu ;;
|
||||||
*Background*) omarchy-theme-bg-next ;;
|
*Background*) omarchy-theme-bg-next ;;
|
||||||
*Screensaver*) edit_in_nvim ~/.config/omarchy/branding/screensaver.txt ;;
|
|
||||||
*About*) edit_in_nvim ~/.config/omarchy/branding/about.txt ;;
|
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -115,10 +117,10 @@ show_screenrecord_menu() {
|
|||||||
|
|
||||||
show_toggle_menu() {
|
show_toggle_menu() {
|
||||||
case $(menu "Toggle" " Screensaver\n Nightlight\n Idle Lock\n Top Bar") in
|
case $(menu "Toggle" " Screensaver\n Nightlight\n Idle Lock\n Top Bar") in
|
||||||
*Screensaver*) omarchy-toggle-screensaver ;;
|
*Screensaver*) omarchy-launch-screensaver ;;
|
||||||
*Nightlight*) omarchy-toggle-nightlight ;;
|
*Nightlight*) omarchy-toggle-nightlight ;;
|
||||||
*Idle*) omarchy-toggle-idle ;;
|
*Idle*) omarchy-toggle-idle ;;
|
||||||
*Bar*) omarchy-toggle-waybar ;;
|
*Bar*) pkill -SIGUSR1 waybar ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -131,7 +133,7 @@ show_setup_menu() {
|
|||||||
|
|
||||||
case $(menu "Setup" "$options") in
|
case $(menu "Setup" "$options") in
|
||||||
*Audio*) alacritty --class=Wiremix -e wiremix ;;
|
*Audio*) alacritty --class=Wiremix -e wiremix ;;
|
||||||
*Wifi*) alacritty --class=Impala -e bash -c "rfkill unblock wifi; impala" ;;
|
*Wifi*) alacritty --class=Impala -e impala ;;
|
||||||
*Bluetooth*) blueberry ;;
|
*Bluetooth*) blueberry ;;
|
||||||
*Power*) show_setup_power_menu ;;
|
*Power*) show_setup_power_menu ;;
|
||||||
*Monitors*) edit_in_nvim ~/.config/hypr/monitors.conf ;;
|
*Monitors*) edit_in_nvim ~/.config/hypr/monitors.conf ;;
|
||||||
@@ -169,10 +171,9 @@ show_setup_config_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_install_menu() {
|
show_install_menu() {
|
||||||
case $(menu "Install" " Package\n Web App\n TUI\n Service\n Style\n Development\n Editor\n AI\n Gaming") in
|
case $(menu "Install" " Package\n Web App\n Service\n Style\n Development\n Editor\n AI\n Gaming") in
|
||||||
*Package*) terminal omarchy-pkg-install ;;
|
*Package*) terminal omarchy-pkg-install ;;
|
||||||
*Web*) present_terminal omarchy-webapp-install ;;
|
*Web*) present_terminal omarchy-webapp-install ;;
|
||||||
*TUI*) present_terminal omarchy-tui-install ;;
|
|
||||||
*Service*) show_install_service_menu ;;
|
*Service*) show_install_service_menu ;;
|
||||||
*Style*) show_install_style_menu ;;
|
*Style*) show_install_style_menu ;;
|
||||||
*Development*) show_install_development_menu ;;
|
*Development*) show_install_development_menu ;;
|
||||||
@@ -184,8 +185,7 @@ show_install_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_install_service_menu() {
|
show_install_service_menu() {
|
||||||
case $(menu "Install" " Firewall\n Dropbox\n Tailscale") in
|
case $(menu "Install" " Dropbox\n Tailscale") in
|
||||||
*Firewall*) present_terminal omarchy-install-firewall ;;
|
|
||||||
*Dropbox*) present_terminal omarchy-install-dropbox ;;
|
*Dropbox*) present_terminal omarchy-install-dropbox ;;
|
||||||
*Tailscale*) present_terminal omarchy-install-tailscale ;;
|
*Tailscale*) present_terminal omarchy-install-tailscale ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
@@ -251,7 +251,7 @@ show_install_development_menu() {
|
|||||||
*Go*) present_terminal "omarchy-install-dev-env go" ;;
|
*Go*) present_terminal "omarchy-install-dev-env go" ;;
|
||||||
*PHP*) show_install_php_menu ;;
|
*PHP*) show_install_php_menu ;;
|
||||||
*Python*) present_terminal "omarchy-install-dev-env python" ;;
|
*Python*) present_terminal "omarchy-install-dev-env python" ;;
|
||||||
*Elixir*) show_install_elixir_menu ;;
|
*Elixir*) present_terminal "omarchy-install-dev-env elixir" ;;
|
||||||
*Zig*) present_terminal "omarchy-install-dev-env zig" ;;
|
*Zig*) present_terminal "omarchy-install-dev-env zig" ;;
|
||||||
*Rust*) present_terminal "omarchy-install-dev-env rust" ;;
|
*Rust*) present_terminal "omarchy-install-dev-env rust" ;;
|
||||||
*Java*) present_terminal "omarchy-install-dev-env java" ;;
|
*Java*) present_terminal "omarchy-install-dev-env java" ;;
|
||||||
@@ -279,19 +279,10 @@ show_install_php_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_elixir_menu() {
|
|
||||||
case $(menu "Install" " Elixir\n Phoenix") in
|
|
||||||
*Elixir*) present_terminal "omarchy-install-dev-env elixir" ;;
|
|
||||||
*Phoenix*) present_terminal "omarchy-install-dev-env phoenix" ;;
|
|
||||||
*) show_install_development_menu ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
show_remove_menu() {
|
show_remove_menu() {
|
||||||
case $(menu "Remove" " Package\n Web App\n TUI\n Theme\n Fingerprint\n Fido2") in
|
case $(menu "Remove" " Package\n Web App\n Theme\n Fingerprint\n Fido2") in
|
||||||
*Package*) terminal omarchy-pkg-remove ;;
|
*Package*) terminal omarchy-pkg-remove ;;
|
||||||
*Web*) present_terminal omarchy-webapp-remove ;;
|
*Web*) present_terminal omarchy-webapp-remove ;;
|
||||||
*TUI*) present_terminal omarchy-tui-remove ;;
|
|
||||||
*Theme*) present_terminal omarchy-theme-remove ;;
|
*Theme*) present_terminal omarchy-theme-remove ;;
|
||||||
*Fingerprint*) present_terminal "omarchy-setup-fingerprint --remove" ;;
|
*Fingerprint*) present_terminal "omarchy-setup-fingerprint --remove" ;;
|
||||||
*Fido2*) present_terminal "omarchy-setup-fido2 --remove" ;;
|
*Fido2*) present_terminal "omarchy-setup-fido2 --remove" ;;
|
||||||
@@ -336,9 +327,8 @@ show_update_config_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_system_menu() {
|
show_system_menu() {
|
||||||
case $(menu "System" " Lock\n Screensaver\n Suspend\n Relaunch\n Restart\n Shutdown") in
|
case $(menu "System" " Lock\n Suspend\n Relaunch\n Restart\n Shutdown") in
|
||||||
*Lock*) omarchy-lock-screen ;;
|
*Lock*) omarchy-lock-screen ;;
|
||||||
*Screensaver*) omarchy-launch-screensaver force ;;
|
|
||||||
*Suspend*) systemctl suspend ;;
|
*Suspend*) systemctl suspend ;;
|
||||||
*Relaunch*) uwsm stop ;;
|
*Relaunch*) uwsm stop ;;
|
||||||
*Restart*) systemctl reboot ;;
|
*Restart*) systemctl reboot ;;
|
||||||
@@ -366,7 +356,7 @@ go_to_menu() {
|
|||||||
*remove*) show_remove_menu ;;
|
*remove*) show_remove_menu ;;
|
||||||
*update*) show_update_menu ;;
|
*update*) show_update_menu ;;
|
||||||
*system*) show_system_menu ;;
|
*system*) show_system_menu ;;
|
||||||
*about*) terminal bash -c 'fastfetch; read -n 1 -s' ;;
|
*about*) gtk-launch About.desktop ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -31,10 +31,7 @@ dynamic_bindings() {
|
|||||||
-e 's/^65,/SUPER SHIFT,/' \
|
-e 's/^65,/SUPER SHIFT,/' \
|
||||||
-e 's/^68,/SUPER CTRL,/' \
|
-e 's/^68,/SUPER CTRL,/' \
|
||||||
-e 's/^69,/SUPER SHIFT CTRL,/' \
|
-e 's/^69,/SUPER SHIFT CTRL,/' \
|
||||||
-e 's/^72,/SUPER ALT,/' \
|
-e 's/^72,/SUPER ALT,/'
|
||||||
-e 's/^73,/SUPER SHIFT ALT,/' \
|
|
||||||
-e 's/^76,/SUPER CTRL ALT,/' \
|
|
||||||
-e 's/^77,/SUPER SHIFT CTRL ALT,/'
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Parse and format keybindings
|
# Parse and format keybindings
|
||||||
|
|||||||
@@ -1,24 +1,18 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'yay -Sii {1}'
|
--preview 'echo "alt-p: toggle description, alt-j/k: scroll, F11: maximize"; echo; yay -Sii {1}'
|
||||||
--preview-label='alt-p: toggle description, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
|
||||||
--preview-label-pos='bottom'
|
|
||||||
--preview-window 'down:65%:wrap'
|
--preview-window 'down:65%:wrap'
|
||||||
--bind 'alt-p:toggle-preview'
|
--bind 'alt-p:toggle-preview'
|
||||||
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
||||||
--bind 'alt-k:preview-up,alt-j:preview-down'
|
--bind 'alt-k:preview-up,alt-j:preview-down'
|
||||||
--color 'pointer:green,marker:green'
|
|
||||||
)
|
)
|
||||||
|
|
||||||
pkg_names=$(yay -Slq | fzf "${fzf_args[@]}")
|
pkg_name=$(yay -Slq | fzf "${fzf_args[@]}")
|
||||||
|
|
||||||
if [[ -n "$pkg_names" ]]; then
|
if [[ -n "$pkg_name" ]]; then
|
||||||
# Convert newline-separated selections to space-separated for yay
|
yay -Sy --noconfirm "$pkg_name"
|
||||||
echo "$pkg_names" | tr '\n' ' ' | xargs yay -Sy --noconfirm
|
|
||||||
sudo updatedb
|
sudo updatedb
|
||||||
omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -2,21 +2,17 @@
|
|||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'yay -Qi {1}'
|
--preview 'echo "alt-p: toggle description, alt-j/k: scroll, F11: maximize"; echo; yay -Qi {1}'
|
||||||
--preview-label='alt-p: toggle description, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
|
||||||
--preview-label-pos='bottom'
|
|
||||||
--preview-window 'down:65%:wrap'
|
--preview-window 'down:65%:wrap'
|
||||||
--bind 'alt-p:toggle-preview'
|
--bind 'alt-p:toggle-preview'
|
||||||
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
||||||
--bind 'alt-k:preview-up,alt-j:preview-down'
|
--bind 'alt-k:preview-up,alt-j:preview-down'
|
||||||
--color 'pointer:red,marker:red'
|
|
||||||
)
|
)
|
||||||
|
|
||||||
pkg_names=$(yay -Qqe | fzf "${fzf_args[@]}")
|
pkg_name=$(yay -Qqe | fzf "${fzf_args[@]}")
|
||||||
|
|
||||||
if [[ -n "$pkg_names" ]]; then
|
if [[ -n "$pkg_name" ]]; then
|
||||||
# Convert newline-separated selections to space-separated for yay
|
yay -Rns --noconfirm "$pkg_name"
|
||||||
echo "$pkg_names" | tr '\n' ' ' | xargs yay -Rns --noconfirm
|
|
||||||
sudo updatedb
|
sudo updatedb
|
||||||
omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,4 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
echo "Resetting sudo lockout for user: $USER"
|
|
||||||
su -c "faillock --reset --user $USER"
|
|
||||||
@@ -1,7 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
pkill walker
|
pkill walker
|
||||||
# FIXME: Reenable the walker service once the memory leak has been fixed
|
setsid uwsm app -- walker --gapplication-service &
|
||||||
# See https://github.com/basecamp/omarchy/issues/698
|
|
||||||
# setsid uwsm app -- walker --gapplication-service &
|
|
||||||
echo # Always end in success so we don't terminate further running
|
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ else
|
|||||||
echo -e "\e[32mLet's setup your fingerprint scanner for authentication.\n\e[0m"
|
echo -e "\e[32mLet's setup your fingerprint scanner for authentication.\n\e[0m"
|
||||||
yay -S --noconfirm --needed fprintd usbutils
|
yay -S --noconfirm --needed fprintd usbutils
|
||||||
|
|
||||||
if ! lsusb | grep -Eiq 'fingerprint|synaptics|goodix|elan'; then
|
if ! lsusb | grep -Eiq 'fingerprint|synaptics|goodix'; then
|
||||||
echo -e "\e[31m\nNo fingerprint sensor detected.\e[0m"
|
echo -e "\e[31m\nNo fingerprint sensor detected.\e[0m"
|
||||||
else
|
else
|
||||||
# Add fingerprint authentication as an option for sudo
|
# Add fingerprint authentication as an option for sudo
|
||||||
|
|||||||
@@ -1,27 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
COMMAND="$1"
|
|
||||||
OMARCHY_PATH=${OMARCHY_PATH:-$HOME/.local/share/omarchy}
|
|
||||||
|
|
||||||
if [[ -z $COMMAND ]]; then
|
|
||||||
echo "Usage: omarchy-snapshot <create|restore>" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! command -v snapper &>/dev/null; then
|
|
||||||
echo "You need Snapper installed to be able to use omarchy-snapshot."
|
|
||||||
exit 127
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$COMMAND" in
|
|
||||||
create)
|
|
||||||
DESC="$(omarchy-version)"
|
|
||||||
|
|
||||||
for config in root home; do
|
|
||||||
sudo snapper -c "$config" create -c number -d "$DESC"
|
|
||||||
done
|
|
||||||
;;
|
|
||||||
restore)
|
|
||||||
sudo limine-snapper-restore
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
@@ -1,63 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Status indicator daemon for waybar
|
|
||||||
# Calls individual status scripts and caches results
|
|
||||||
|
|
||||||
STATE_DIR=~/.local/state/omarchy/status
|
|
||||||
DAEMON_PID_FILE="$STATE_DIR/daemon.pid"
|
|
||||||
SCRIPT_DIR="$(dirname "$(readlink -f "$0")")"
|
|
||||||
|
|
||||||
mkdir -p "$STATE_DIR"
|
|
||||||
|
|
||||||
# Update all status files by calling individual scripts
|
|
||||||
update_all_status_files() {
|
|
||||||
"$SCRIPT_DIR/omarchy-status-dnd" >"$STATE_DIR/dnd"
|
|
||||||
"$SCRIPT_DIR/omarchy-status-nightlight" >"$STATE_DIR/nightlight"
|
|
||||||
"$SCRIPT_DIR/omarchy-status-idle" >"$STATE_DIR/idle"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Generate hash for change detection
|
|
||||||
get_status_hash() {
|
|
||||||
echo "$($(makoctl mode 2>/dev/null | grep -c 'do-not-disturb')$(hyprctl hyprsunset temperature 2>/dev/null)"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Start background monitoring daemon
|
|
||||||
start_daemon() {
|
|
||||||
if [ -f "$DAEMON_PID_FILE" ] && kill -0 $(cat "$DAEMON_PID_FILE") 2>/dev/null; then
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
{
|
|
||||||
last_hash=""
|
|
||||||
while true; do
|
|
||||||
current_hash=$(get_status_hash)
|
|
||||||
|
|
||||||
if [ "$current_hash" != "$last_hash" ]; then
|
|
||||||
update_all_status_files
|
|
||||||
last_hash="$current_hash"
|
|
||||||
fi
|
|
||||||
|
|
||||||
sleep 0.5
|
|
||||||
done
|
|
||||||
} &
|
|
||||||
|
|
||||||
echo $! >"$DAEMON_PID_FILE"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Main execution
|
|
||||||
MODULE="$1"
|
|
||||||
|
|
||||||
if [ -z "$MODULE" ]; then
|
|
||||||
echo "Usage: $0 [dnd|nightlight|idle]"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
start_daemon
|
|
||||||
|
|
||||||
# Return cached status for requested module
|
|
||||||
if [ -f "$STATE_DIR/$MODULE" ]; then
|
|
||||||
cat "$STATE_DIR/$MODULE"
|
|
||||||
else
|
|
||||||
update_all_status_files
|
|
||||||
cat "$STATE_DIR/$MODULE" 2>/dev/null || echo '{"text": "", "tooltip": "", "class": "hidden"}'
|
|
||||||
fi
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# DND status indicator
|
|
||||||
|
|
||||||
if makoctl mode 2>/dev/null | grep -q 'do-not-disturb'; then
|
|
||||||
echo '{"text": "", "tooltip": "Notifications silenced", "class": "status-dnd"}'
|
|
||||||
else
|
|
||||||
echo '{"text": "", "tooltip": "", "class": "hidden"}'
|
|
||||||
fi
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Idle lock status indicator
|
|
||||||
|
|
||||||
if command -v hypridle >/dev/null 2>&1 && ! pgrep -x hypridle >/dev/null 2>&1; then
|
|
||||||
echo '{"text": "", "tooltip": "Idle lock disabled", "class": "status-idle"}'
|
|
||||||
else
|
|
||||||
echo '{"text": "", "tooltip": "", "class": "hidden"}'
|
|
||||||
fi
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Nightlight status indicator
|
|
||||||
|
|
||||||
if pgrep -x hyprsunset >/dev/null 2>&1; then
|
|
||||||
temp=$(hyprctl hyprsunset temperature 2>/dev/null | grep -oE '[0-9]+')
|
|
||||||
if [ -n "$temp" ] && [ "$temp" -lt 6000 ]; then
|
|
||||||
echo '{"text": "", "tooltip": "Night light active", "class": "status-nightlight"}'
|
|
||||||
else
|
|
||||||
echo '{"text": "", "tooltip": "", "class": "hidden"}'
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo '{"text": "", "tooltip": "", "class": "hidden"}'
|
|
||||||
fi
|
|
||||||
@@ -39,14 +39,6 @@ else
|
|||||||
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Change Chromium colors
|
|
||||||
if [[ -f ~/.config/omarchy/current/theme/chromium.theme ]] && command -v chromium &>/dev/null; then
|
|
||||||
chromium --no-startup-window --set-theme-color="$(<~/.config/omarchy/current/theme/chromium.theme)"
|
|
||||||
else
|
|
||||||
# Use a default, neutral grey if theme doesn't have a color
|
|
||||||
chromium --no-startup-window --set-theme-color="28,32,39"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Trigger alacritty config reload
|
# Trigger alacritty config reload
|
||||||
touch "$HOME/.config/alacritty/alacritty.toml"
|
touch "$HOME/.config/alacritty/alacritty.toml"
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
STATE_FILE=~/.local/state/omarchy/toggles/screensaver-off
|
|
||||||
|
|
||||||
if [[ -f $STATE_FILE ]]; then
|
|
||||||
rm -f $STATE_FILE
|
|
||||||
notify-send " Screensaver enabled"
|
|
||||||
else
|
|
||||||
mkdir -p "$(dirname $STATE_FILE)"
|
|
||||||
touch $STATE_FILE
|
|
||||||
notify-send " Screensaver disabled"
|
|
||||||
fi
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if pgrep -x waybar >/dev/null; then
|
|
||||||
pkill -x waybar
|
|
||||||
else
|
|
||||||
uwsm app -- waybar >/dev/null 2>&1 &
|
|
||||||
fi
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if [ "$#" -ne 4 ]; then
|
|
||||||
echo -e "\e[32mLet's create a TUI shortcut you can start with the app launcher.\n\e[0m"
|
|
||||||
APP_NAME=$(gum input --prompt "Name> " --placeholder "My TUI")
|
|
||||||
APP_EXEC=$(gum input --prompt "Launch Command> " --placeholder "lazydocker or bash -c 'dust; read -n 1 -s'")
|
|
||||||
WINDOW_STYLE=$(gum choose --header "Window style" float tile)
|
|
||||||
ICON_URL=$(gum input --prompt "Icon URL> " --placeholder "See https://dashboardicons.com (must use PNG!)")
|
|
||||||
else
|
|
||||||
APP_NAME="$1"
|
|
||||||
APP_EXEC="$2"
|
|
||||||
WINDOW_STYLE="$3"
|
|
||||||
ICON_URL="$4"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z "$APP_NAME" || -z "$APP_EXEC" || -z "$ICON_URL" ]]; then
|
|
||||||
echo "You must set app name, app command, and icon URL!"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
|
||||||
DESKTOP_FILE="$HOME/.local/share/applications/$APP_NAME.desktop"
|
|
||||||
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
|
||||||
|
|
||||||
mkdir -p "$ICON_DIR"
|
|
||||||
|
|
||||||
if ! curl -sL -o "$ICON_PATH" "$ICON_URL"; then
|
|
||||||
echo "Error: Failed to download icon."
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ $WINDOW_STYLE == "float" ]]; then
|
|
||||||
APP_CLASS="TUI.float"
|
|
||||||
else
|
|
||||||
APP_CLASS="TUI.tile"
|
|
||||||
fi
|
|
||||||
|
|
||||||
cat >"$DESKTOP_FILE" <<EOF
|
|
||||||
[Desktop Entry]
|
|
||||||
Version=1.0
|
|
||||||
Name=$APP_NAME
|
|
||||||
Comment=$APP_NAME
|
|
||||||
Exec=alacritty --class $APP_CLASS -e $APP_EXEC
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
Icon=$ICON_PATH
|
|
||||||
StartupNotify=true
|
|
||||||
EOF
|
|
||||||
|
|
||||||
chmod +x "$DESKTOP_FILE"
|
|
||||||
|
|
||||||
if [ "$#" -ne 4 ]; then
|
|
||||||
echo -e "You can now find $APP_NAME using the app launcher (SUPER + SPACE)\n"
|
|
||||||
fi
|
|
||||||
@@ -1,36 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
|
||||||
DESKTOP_DIR="$HOME/.local/share/applications/"
|
|
||||||
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
# Find all web apps
|
|
||||||
while IFS= read -r -d '' file; do
|
|
||||||
if grep -q '^Exec=.*alacritty.*-e' "$file"; then
|
|
||||||
TUIS+=("$(basename "${file%.desktop}")")
|
|
||||||
fi
|
|
||||||
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
|
||||||
|
|
||||||
if ((${#TUIS[@]})); then
|
|
||||||
IFS=$'\n' SORTED_TUIS=($(sort <<<"${TUIS[*]}"))
|
|
||||||
unset IFS
|
|
||||||
APP_NAME=$(gum choose --header "Select TUI to remove..." "${SORTED_TUIS[@]}")
|
|
||||||
else
|
|
||||||
echo "No TUIs to remove."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
APP_NAME="$1"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z "$APP_NAME" ]]; then
|
|
||||||
echo "You must provide TUI name."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
rm "$DESKTOP_DIR/$APP_NAME.desktop"
|
|
||||||
rm "$ICON_DIR/$APP_NAME.png"
|
|
||||||
|
|
||||||
if [ "$#" -ne 1 ]; then
|
|
||||||
echo -e "Removed $APP_NAME\n"
|
|
||||||
fi
|
|
||||||
@@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
omarchy-snapshot create || [ $? -eq 127 ]
|
|
||||||
omarchy-update-git
|
omarchy-update-git
|
||||||
omarchy-migrate
|
omarchy-migrate
|
||||||
omarchy-update-system-pkgs
|
omarchy-update-system-pkgs
|
||||||
|
|||||||
@@ -1,13 +1,15 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
omarchy_path="$HOME/.local/share/omarchy"
|
||||||
|
|
||||||
# Ensure remote is reachable
|
# Ensure remote is reachable
|
||||||
if ! git -C "$OMARCHY_PATH" ls-remote &>/dev/null; then
|
if ! git -C "$omarchy_path" ls-remote &>/dev/null; then
|
||||||
echo "Error: Unable to reach remote repository."
|
echo "Error: Unable to reach remote repository."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
latest_tag=$(git -C "$OMARCHY_PATH" ls-remote --tags origin | grep -v "{}" | awk '{print $2}' | sed 's#refs/tags/##' | sort -V | tail -n 1)
|
latest_tag=$(git -C "$omarchy_path" ls-remote --tags origin | grep -v "{}" | awk '{print $2}' | sed 's#refs/tags/##' | sort -V | tail -n 1)
|
||||||
current_tag=$(git -C "$OMARCHY_PATH" describe --tags $(git -C "$OMARCHY_PATH" rev-list --tags --max-count=1))
|
current_tag=$(git -C "$omarchy_path" describe --tags $(git -C "$omarchy_path" rev-list --tags --max-count=1))
|
||||||
|
|
||||||
if [[ "$current_tag" != "$latest_tag" ]]; then
|
if [[ "$current_tag" != "$latest_tag" ]]; then
|
||||||
echo "Omarchy update available ($latest_tag)"
|
echo "Omarchy update available ($latest_tag)"
|
||||||
|
|||||||
@@ -1,24 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Check for kernel package updates since last boot
|
if [ "$(uname -r | sed 's/-arch/\.arch/')" != "$(pacman -Q linux | awk '{print $2}')" ]; then
|
||||||
boot_time=$(date -d "$(uptime -s)" '+%Y-%m-%d %H:%M')
|
gum confirm "New Linux kernel requires reboot. Ready?" && omarchy-state clear re*-required && sudo reboot now
|
||||||
recent_kernel_updates=$(awk -v boot_time="$boot_time" '$0 >="["boot_time' /var/log/pacman.log | grep -E "\[ALPM\] (upgraded|installed) (linux|linux-zen|linux-lts|linux-hardened)\b" || true)
|
|
||||||
if [ -n "$recent_kernel_updates" ]; then
|
|
||||||
gum confirm "Linux kernel has been updated. Reboot?" && omarchy-state clear re*-required && sudo reboot now
|
|
||||||
|
|
||||||
elif [ -f "$HOME/.local/state/omarchy/reboot-required" ]; then
|
elif [ -f "$HOME/.local/state/omarchy/reboot-required" ]; then
|
||||||
gum confirm "Updates require reboot. Ready?" && omarchy-state clear re*-required && sudo reboot now
|
gum confirm "Updates require reboot. Ready?" && omarchy-state clear re*-required && sudo reboot now
|
||||||
|
|
||||||
elif [ -f "$HOME/.local/state/omarchy/relaunch-required" ]; then
|
elif [ -f "$HOME/.local/state/omarchy/relaunch-required" ]; then
|
||||||
gum confirm "Updates require Hyprland relaunch. Ready?" && omarchy-state clear re*-required && uwsm stop
|
gum confirm "Updates require Hyprland relaunch. Ready?" && omarchy-state clear relaunch-required && uwsm stop
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for file in "$HOME"/.local/state/omarchy/restart-*-required; do
|
|
||||||
if [ -f "$file" ]; then
|
|
||||||
filename=$(basename "$file")
|
|
||||||
service=$(echo "$filename" | sed 's/restart-\(.*\)-required/\1/')
|
|
||||||
echo "Restarting $service"
|
|
||||||
omarchy-state clear "$filename"
|
|
||||||
omarchy-restart-"$service"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo -e "\e[32m\nUpdate system packages\e[0m"
|
echo -e "\e[32m\nUpdate system packages\e[0m"
|
||||||
yay -Syu --noconfirm
|
yay -Syu --noconfirm --ignore uwsm
|
||||||
echo
|
echo
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ cat >"$DESKTOP_FILE" <<EOF
|
|||||||
Version=1.0
|
Version=1.0
|
||||||
Name=$APP_NAME
|
Name=$APP_NAME
|
||||||
Comment=$APP_NAME
|
Comment=$APP_NAME
|
||||||
Exec=omarchy-launch-webapp $APP_URL
|
Exec=chromium --new-window --ozone-platform=wayland --app="$APP_URL" --name="$APP_NAME" --class="$APP_NAME"
|
||||||
Terminal=false
|
Terminal=false
|
||||||
Type=Application
|
Type=Application
|
||||||
Icon=$ICON_PATH
|
Icon=$ICON_PATH
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ DESKTOP_DIR="$HOME/.local/share/applications/"
|
|||||||
if [ "$#" -ne 1 ]; then
|
if [ "$#" -ne 1 ]; then
|
||||||
# Find all web apps
|
# Find all web apps
|
||||||
while IFS= read -r -d '' file; do
|
while IFS= read -r -d '' file; do
|
||||||
if grep -q '^Exec=.*omarchy-launch-webapp.*' "$file"; then
|
if grep -q '^Exec=.*chromium.*--app' "$file"; then
|
||||||
WEB_APPS+=("$(basename "${file%.desktop}")")
|
WEB_APPS+=("$(basename "${file%.desktop}")")
|
||||||
fi
|
fi
|
||||||
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
||||||
|
|||||||
5
boot.sh
5
boot.sh
@@ -23,9 +23,8 @@ echo -e "\nCloning Omarchy from: https://github.com/${OMARCHY_REPO}.git"
|
|||||||
rm -rf ~/.local/share/omarchy/
|
rm -rf ~/.local/share/omarchy/
|
||||||
git clone "https://github.com/${OMARCHY_REPO}.git" ~/.local/share/omarchy >/dev/null
|
git clone "https://github.com/${OMARCHY_REPO}.git" ~/.local/share/omarchy >/dev/null
|
||||||
|
|
||||||
# Use custom branch if instructed, otherwise default to master
|
# Use custom branch if instructed
|
||||||
OMARCHY_REF="${OMARCHY_REF:-master}"
|
if [[ -n "$OMARCHY_REF" ]]; then
|
||||||
if [[ $OMARCHY_REF != "master" ]]; then
|
|
||||||
echo -e "\eUsing branch: $OMARCHY_REF"
|
echo -e "\eUsing branch: $OMARCHY_REF"
|
||||||
cd ~/.local/share/omarchy
|
cd ~/.local/share/omarchy
|
||||||
git fetch origin "${OMARCHY_REF}" && git checkout "${OMARCHY_REF}"
|
git fetch origin "${OMARCHY_REF}" && git checkout "${OMARCHY_REF}"
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
--ozone-platform=wayland
|
|
||||||
--ozone-platform-hint=wayland
|
|
||||||
--enable-features=TouchpadOverscrollHistoryNavigation
|
|
||||||
@@ -1,13 +1,9 @@
|
|||||||
{
|
{
|
||||||
"$schema": "https://github.com/fastfetch-cli/fastfetch/raw/dev/doc/json_schema.json",
|
"$schema": "https://github.com/fastfetch-cli/fastfetch/raw/dev/doc/json_schema.json",
|
||||||
"logo": {
|
"logo": {
|
||||||
"type": "file",
|
|
||||||
"source": "~/.config/omarchy/branding/about.txt",
|
|
||||||
"color": { "1": "green" },
|
|
||||||
"padding": {
|
"padding": {
|
||||||
"top": 2,
|
"top": 5,
|
||||||
"right": 6,
|
"right": 6
|
||||||
"left": 2
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"modules": [
|
"modules": [
|
||||||
@@ -89,12 +85,6 @@
|
|||||||
"keyColor": "blue",
|
"keyColor": "blue",
|
||||||
"text": "version=$(git -C ~/.local/share/omarchy describe --tags --abbrev=0 2>/dev/null); echo \"Omarchy $version\""
|
"text": "version=$(git -C ~/.local/share/omarchy describe --tags --abbrev=0 2>/dev/null); echo \"Omarchy $version\""
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"type": "command",
|
|
||||||
"key": "│ ├",
|
|
||||||
"keyColor": "blue",
|
|
||||||
"text": "theme=$(omarchy-theme-current); echo -e \"$theme \\e[38m●\\e[37m●\\e[36m●\\e[35m●\\e[34m●\\e[33m●\\e[32m●\\e[31m●\""
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"type": "de",
|
"type": "de",
|
||||||
"key": " DE",
|
"key": " DE",
|
||||||
|
|||||||
@@ -1 +0,0 @@
|
|||||||
Allow Overriding System XKB Settings=False
|
|
||||||
@@ -1,8 +1,9 @@
|
|||||||
# Application bindings
|
# Application bindings
|
||||||
$terminal = uwsm app -- alacritty
|
$terminal = uwsm app -- alacritty
|
||||||
$browser = omarchy-launch-browser
|
$browser = uwsm app -- chromium --new-window --ozone-platform=wayland
|
||||||
|
$webapp = $browser --app
|
||||||
|
|
||||||
bindd = SUPER, return, Terminal, exec, $terminal --working-directory $(omarchy-cmd-terminal-cwd)
|
bindd = SUPER, return, Terminal, exec, $terminal
|
||||||
bindd = SUPER, F, File manager, exec, uwsm app -- nautilus --new-window
|
bindd = SUPER, F, File manager, exec, uwsm app -- nautilus --new-window
|
||||||
bindd = SUPER, B, Browser, exec, $browser
|
bindd = SUPER, B, Browser, exec, $browser
|
||||||
bindd = SUPER, M, Music, exec, uwsm app -- spotify
|
bindd = SUPER, M, Music, exec, uwsm app -- spotify
|
||||||
@@ -13,16 +14,15 @@ bindd = SUPER, G, Signal, exec, uwsm app -- signal-desktop
|
|||||||
bindd = SUPER, O, Obsidian, exec, uwsm app -- obsidian -disable-gpu
|
bindd = SUPER, O, Obsidian, exec, uwsm app -- obsidian -disable-gpu
|
||||||
bindd = SUPER, slash, Passwords, exec, uwsm app -- 1password
|
bindd = SUPER, slash, Passwords, exec, uwsm app -- 1password
|
||||||
|
|
||||||
# If your web app url contains #, type it as ## to prevent hyperland treat it as comments
|
bindd = SUPER, A, ChatGPT, exec, $webapp="https://chatgpt.com"
|
||||||
bindd = SUPER, A, ChatGPT, exec, omarchy-launch-webapp "https://chatgpt.com"
|
bindd = SUPER SHIFT, A, Grok, exec, $webapp="https://grok.com"
|
||||||
bindd = SUPER SHIFT, A, Grok, exec, omarchy-launch-webapp "https://grok.com"
|
bindd = SUPER, C, Calendar, exec, $webapp="https://app.hey.com/calendar/weeks/"
|
||||||
bindd = SUPER, C, Calendar, exec, omarchy-launch-webapp "https://app.hey.com/calendar/weeks/"
|
bindd = SUPER, E, Email, exec, $webapp="https://app.hey.com"
|
||||||
bindd = SUPER, E, Email, exec, omarchy-launch-webapp "https://app.hey.com"
|
bindd = SUPER, Y, YouTube, exec, $webapp="https://youtube.com/"
|
||||||
bindd = SUPER, Y, YouTube, exec, omarchy-launch-webapp "https://youtube.com/"
|
bindd = SUPER SHIFT, G, WhatsApp, exec, $webapp="https://web.whatsapp.com/"
|
||||||
bindd = SUPER SHIFT, G, WhatsApp, exec, omarchy-launch-webapp "https://web.whatsapp.com/"
|
bindd = SUPER ALT, G, Google Messages, exec, $webapp="https://messages.google.com/web/conversations"
|
||||||
bindd = SUPER ALT, G, Google Messages, exec, omarchy-launch-webapp "https://messages.google.com/web/conversations"
|
bindd = SUPER, X, X, exec, $webapp="https://x.com/"
|
||||||
bindd = SUPER, X, X, exec, omarchy-launch-webapp "https://x.com/"
|
bindd = SUPER SHIFT, X, X Post, exec, $webapp="https://x.com/compose/post"
|
||||||
bindd = SUPER SHIFT, X, X Post, exec, omarchy-launch-webapp "https://x.com/compose/post"
|
|
||||||
|
|
||||||
# Overwrite existing bindings, like putting Omarchy Menu on Super + Space
|
# Overwrite existing bindings, like putting Omarchy Menu on Super + Space
|
||||||
# unbind = SUPER, Space
|
# unbind = SUPER, Space
|
||||||
|
|||||||
@@ -5,10 +5,11 @@ general {
|
|||||||
on_unlock_cmd = omarchy-restart-waybar # prevent stacking of waybar when waking
|
on_unlock_cmd = omarchy-restart-waybar # prevent stacking of waybar when waking
|
||||||
}
|
}
|
||||||
|
|
||||||
listener {
|
# FIXME: Scrensaver depends on tte being installed
|
||||||
timeout = 150 # 2.5min
|
# listener {
|
||||||
on-timeout = pidof hyprlock || omarchy-launch-screensaver # start screensaver (if we haven't locked already)
|
# timeout = 150 # 2.5min
|
||||||
}
|
# on-timeout = pidof hyprlock || omarchy-launch-screensaver # start screensaver (if we haven't locked already)
|
||||||
|
# }
|
||||||
|
|
||||||
listener {
|
listener {
|
||||||
timeout = 300 # 5min
|
timeout = 300 # 5min
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
# See https://wiki.hypr.land/Configuring/Variables/#input
|
# See https://wiki.hypr.land/Configuring/Variables/#input
|
||||||
input {
|
input {
|
||||||
# Use multiple keyboard layouts and switch between them with Left Alt + Right Alt
|
# Use multiple keyboard layouts and switch between them with Left Alt + Right Alt
|
||||||
# kb_layout = us,dk,eu
|
# kb_layout = us,dk
|
||||||
kb_options = compose:caps # ,grp:alts_toggle
|
kb_options = compose:caps # ,grp:alts_toggle
|
||||||
|
|
||||||
# Change speed of keyboard repeat
|
# Change speed of keyboard repeat
|
||||||
|
|||||||
Binary file not shown.
@@ -1,32 +0,0 @@
|
|||||||
add_newline = true
|
|
||||||
command_timeout = 200
|
|
||||||
format = "[$directory$git_branch$git_status]($style)$character"
|
|
||||||
|
|
||||||
[character]
|
|
||||||
error_symbol = "[✗](bold cyan)"
|
|
||||||
success_symbol = "[❯](bold cyan)"
|
|
||||||
|
|
||||||
[directory]
|
|
||||||
truncation_length = 2
|
|
||||||
truncation_symbol = "…/"
|
|
||||||
repo_root_style = "bold cyan"
|
|
||||||
repo_root_format = "[$repo_root]($repo_root_style)[$path]($style)[$read_only]($read_only_style) "
|
|
||||||
|
|
||||||
[git_branch]
|
|
||||||
format = "[$branch]($style) "
|
|
||||||
style = "italic cyan"
|
|
||||||
|
|
||||||
[git_status]
|
|
||||||
format = '[$all_status]($style)'
|
|
||||||
style = "cyan"
|
|
||||||
ahead = "⇡${count} "
|
|
||||||
diverged = "⇕⇡${ahead_count}⇣${behind_count} "
|
|
||||||
behind = "⇣${count} "
|
|
||||||
conflicted = " "
|
|
||||||
up_to_date = " "
|
|
||||||
untracked = "? "
|
|
||||||
modified = " "
|
|
||||||
stashed = ""
|
|
||||||
staged = ""
|
|
||||||
renamed = ""
|
|
||||||
deleted = ""
|
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
export OMARCHY_PATH=$HOME/.local/share/omarchy
|
export OMARCHY_PATH=$HOME/.local/share/omarchy
|
||||||
export PATH=$OMARCHY_PATH/bin/:$PATH
|
export PATH=$OMARCHY_PATH/bin/:$PATH
|
||||||
export TERMINAL=alacritty
|
|
||||||
|
|
||||||
if command -v mise &> /dev/null; then
|
if command -v mise &> /dev/null; then
|
||||||
eval "$(mise activate bash)"
|
eval "$(mise activate bash)"
|
||||||
|
|||||||
@@ -4,14 +4,12 @@ theme_base = []
|
|||||||
theme_location = ["~/.local/share/omarchy/default/walker/themes/"]
|
theme_location = ["~/.local/share/omarchy/default/walker/themes/"]
|
||||||
hotreload_theme = true
|
hotreload_theme = true
|
||||||
force_keyboard_focus = true
|
force_keyboard_focus = true
|
||||||
timeout = 60
|
|
||||||
|
|
||||||
[keys.ai]
|
[keys.ai]
|
||||||
run_last_response = ["ctrl e"]
|
run_last_response = ["ctrl e"]
|
||||||
|
|
||||||
[list]
|
[list]
|
||||||
max_entries = 200
|
max_entries = 200
|
||||||
cycle = true
|
|
||||||
|
|
||||||
[search]
|
[search]
|
||||||
placeholder = " Search..."
|
placeholder = " Search..."
|
||||||
|
|||||||
@@ -4,8 +4,14 @@
|
|||||||
"position": "top",
|
"position": "top",
|
||||||
"spacing": 0,
|
"spacing": 0,
|
||||||
"height": 26,
|
"height": 26,
|
||||||
"modules-left": ["custom/omarchy", "hyprland/workspaces"],
|
"modules-left": [
|
||||||
"modules-center": ["group/status-cluster", "clock", "custom/update"],
|
"custom/omarchy",
|
||||||
|
"hyprland/workspaces"
|
||||||
|
],
|
||||||
|
"modules-center": [
|
||||||
|
"clock",
|
||||||
|
"custom/update"
|
||||||
|
],
|
||||||
"modules-right": [
|
"modules-right": [
|
||||||
"group/tray-expander",
|
"group/tray-expander",
|
||||||
"bluetooth",
|
"bluetooth",
|
||||||
@@ -39,7 +45,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"custom/omarchy": {
|
"custom/omarchy": {
|
||||||
"format": "<span font='omarchy'>\ue900</span>",
|
"format": "",
|
||||||
"on-click": "omarchy-menu",
|
"on-click": "omarchy-menu",
|
||||||
"tooltip-format": "Omarchy Menu\n\nSuper + Alt + Space"
|
"tooltip-format": "Omarchy Menu\n\nSuper + Alt + Space"
|
||||||
},
|
},
|
||||||
@@ -50,7 +56,6 @@
|
|||||||
"tooltip-format": "Omarchy update available",
|
"tooltip-format": "Omarchy update available",
|
||||||
"interval": 3600
|
"interval": 3600
|
||||||
},
|
},
|
||||||
|
|
||||||
"cpu": {
|
"cpu": {
|
||||||
"interval": 5,
|
"interval": 5,
|
||||||
"format": "",
|
"format": "",
|
||||||
@@ -63,11 +68,11 @@
|
|||||||
"on-click-right": "omarchy-cmd-tzupdate"
|
"on-click-right": "omarchy-cmd-tzupdate"
|
||||||
},
|
},
|
||||||
"network": {
|
"network": {
|
||||||
"format-icons": ["", "", "", "", ""],
|
"format-icons": ["","","","",""],
|
||||||
"format": "{icon}",
|
"format" : "{icon}",
|
||||||
"format-wifi": "{icon}",
|
"format-wifi" : "{icon}",
|
||||||
"format-ethernet": "",
|
"format-ethernet" : "",
|
||||||
"format-disconnected": "",
|
"format-disconnected" : "",
|
||||||
"tooltip-format-wifi": "{essid} ({frequency} GHz)\n⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
"tooltip-format-wifi": "{essid} ({frequency} GHz)\n⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
||||||
"tooltip-format-ethernet": "⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
"tooltip-format-ethernet": "⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
||||||
"tooltip-format-disconnected": "Disconnected",
|
"tooltip-format-disconnected": "Disconnected",
|
||||||
@@ -81,8 +86,12 @@
|
|||||||
"format-charging": "{icon}",
|
"format-charging": "{icon}",
|
||||||
"format-plugged": "",
|
"format-plugged": "",
|
||||||
"format-icons": {
|
"format-icons": {
|
||||||
"charging": ["", "", "", "", "", "", "", "", "", ""],
|
"charging": [
|
||||||
"default": ["", "", "", "", "", "", "", "", "", ""]
|
"", "", "", "", "", "", "", "", "", ""
|
||||||
|
],
|
||||||
|
"default": [
|
||||||
|
"", "", "", "", "", "", "", "", "", ""
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"format-full": "",
|
"format-full": "",
|
||||||
"tooltip-format-discharging": "{power:>1.0f}W↓ {capacity}%",
|
"tooltip-format-discharging": "{power:>1.0f}W↓ {capacity}%",
|
||||||
@@ -117,34 +126,11 @@
|
|||||||
"transition-duration": 600,
|
"transition-duration": 600,
|
||||||
"children-class": "tray-group-item"
|
"children-class": "tray-group-item"
|
||||||
},
|
},
|
||||||
"modules": ["custom/expand-icon", "tray"]
|
|
||||||
},
|
|
||||||
"group/status-cluster": {
|
|
||||||
"orientation": "inherit",
|
|
||||||
"modules": [
|
"modules": [
|
||||||
"custom/status-dnd",
|
"custom/expand-icon",
|
||||||
"custom/status-nightlight",
|
"tray"
|
||||||
"custom/status-idle"
|
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"custom/status-dnd": {
|
|
||||||
"exec": "omarchy-status-daemon dnd",
|
|
||||||
"return-type": "json",
|
|
||||||
"interval": 1,
|
|
||||||
"on-click": "makoctl mode -t do-not-disturb"
|
|
||||||
},
|
|
||||||
"custom/status-nightlight": {
|
|
||||||
"exec": "omarchy-status-daemon nightlight",
|
|
||||||
"return-type": "json",
|
|
||||||
"interval": 1,
|
|
||||||
"on-click": "omarchy-toggle-nightlight"
|
|
||||||
},
|
|
||||||
"custom/status-idle": {
|
|
||||||
"exec": "omarchy-status-daemon idle",
|
|
||||||
"return-type": "json",
|
|
||||||
"interval": 1,
|
|
||||||
"on-click": "omarchy-toggle-idle"
|
|
||||||
},
|
|
||||||
"custom/expand-icon": {
|
"custom/expand-icon": {
|
||||||
"format": " ",
|
"format": " ",
|
||||||
"tooltip": false
|
"tooltip": false
|
||||||
|
|||||||
@@ -36,8 +36,8 @@
|
|||||||
#network,
|
#network,
|
||||||
#bluetooth,
|
#bluetooth,
|
||||||
#pulseaudio,
|
#pulseaudio,
|
||||||
#custom-omarchy,
|
#clock,
|
||||||
#custom-update {
|
#custom-omarchy {
|
||||||
min-width: 12px;
|
min-width: 12px;
|
||||||
margin: 0 7.5px;
|
margin: 0 7.5px;
|
||||||
}
|
}
|
||||||
@@ -49,33 +49,3 @@
|
|||||||
tooltip {
|
tooltip {
|
||||||
padding: 2px;
|
padding: 2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#custom-update {
|
|
||||||
font-size: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#clock {
|
|
||||||
margin-left: 8.75px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#group-status-cluster {
|
|
||||||
margin-right: 8.75px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#custom-status-dnd,
|
|
||||||
#custom-status-nightlight,
|
|
||||||
#custom-status-idle {
|
|
||||||
min-width: 12px;
|
|
||||||
margin: 0 2px;
|
|
||||||
font-size: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#custom-status-dnd.status-dnd,
|
|
||||||
#custom-status-nightlight.status-nightlight,
|
|
||||||
#custom-status-idle.status-idle {
|
|
||||||
opacity: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.hidden {
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ zd() {
|
|||||||
elif [ -d "$1" ]; then
|
elif [ -d "$1" ]; then
|
||||||
builtin cd "$1"
|
builtin cd "$1"
|
||||||
else
|
else
|
||||||
z "$@" && printf "\U000F17A9 " && pwd || echo "Error: Directory not found"
|
z "$@" && printf " \U000F17A9 " && pwd || echo "Error: Directory not found"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
open() {
|
open() {
|
||||||
|
|||||||
@@ -31,7 +31,6 @@ format-drive() {
|
|||||||
sudo parted -s "$1" mklabel gpt
|
sudo parted -s "$1" mklabel gpt
|
||||||
sudo parted -s "$1" mkpart primary ext4 1MiB 100%
|
sudo parted -s "$1" mkpart primary ext4 1MiB 100%
|
||||||
sudo mkfs.ext4 -L "$2" "$([[ $1 == *"nvme"* ]] && echo "${1}p1" || echo "${1}1")"
|
sudo mkfs.ext4 -L "$2" "$([[ $1 == *"nvme"* ]] && echo "${1}p1" || echo "${1}1")"
|
||||||
sudo chmod -R 777 "/run/media/$USER/$2"
|
|
||||||
echo "Drive $1 formatted and labeled '$2'."
|
echo "Drive $1 formatted and labeled '$2'."
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -47,22 +46,7 @@ transcode-video-4K() {
|
|||||||
ffmpeg -i $1 -c:v libx265 -preset slow -crf 24 -c:a aac -b:a 192k ${1%.*}-optimized.mp4
|
ffmpeg -i $1 -c:v libx265 -preset slow -crf 24 -c:a aac -b:a 192k ${1%.*}-optimized.mp4
|
||||||
}
|
}
|
||||||
|
|
||||||
# Transcode any image to JPG image that's great for shrinking wallpapers
|
# Transcode PNG to JPG image that's great for shrinking wallpapers
|
||||||
img2jpg() {
|
transcode-png2jpg() {
|
||||||
magick $1 -quality 95 -strip ${1%.*}.jpg
|
magick $1 -quality 95 -strip ${1%.*}.jpg
|
||||||
}
|
}
|
||||||
|
|
||||||
# Transcode any image to JPG image that's great for sharing online without being too big
|
|
||||||
img2jpg-small() {
|
|
||||||
magick $1 -resize 1080x\> -quality 95 -strip ${1%.*}.jpg
|
|
||||||
}
|
|
||||||
|
|
||||||
# Transcode any image to compressed-but-lossless PNG
|
|
||||||
img2png() {
|
|
||||||
magick "$1" -strip -define png:compression-filter=5 \
|
|
||||||
-define png:compression-level=9 \
|
|
||||||
-define png:compression-strategy=1 \
|
|
||||||
-define png:exclude-chunk=all \
|
|
||||||
"${1%.*}.png"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|||||||
@@ -2,10 +2,6 @@ if command -v mise &> /dev/null; then
|
|||||||
eval "$(mise activate bash)"
|
eval "$(mise activate bash)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if command -v starship &> /dev/null; then
|
|
||||||
eval "$(starship init bash)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if command -v zoxide &> /dev/null; then
|
if command -v zoxide &> /dev/null; then
|
||||||
eval "$(zoxide init bash)"
|
eval "$(zoxide init bash)"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -7,4 +7,3 @@ source = ~/.local/share/omarchy/default/hypr/apps/steam.conf
|
|||||||
source = ~/.local/share/omarchy/default/hypr/apps/system.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/system.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/walker.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/walker.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/1password.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/1password.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/jetbrains.conf
|
|
||||||
|
|||||||
@@ -2,5 +2,5 @@
|
|||||||
windowrule = tile, class:^(Chromium)$
|
windowrule = tile, class:^(Chromium)$
|
||||||
|
|
||||||
# Only slight opacity when unfocused
|
# Only slight opacity when unfocused
|
||||||
windowrule = opacity 1 0.97, class:^(Chromium|chromium|google-chrome|google-chrome-unstable|Brave-browser|brave-browser)$
|
windowrule = opacity 1 0.97, class:^(Chromium|chromium|google-chrome|google-chrome-unstable)$
|
||||||
windowrule = opacity 1 1, initialTitle:(youtube.com_/|app.zoom.us_/wc/home)
|
windowrule = opacity 1 1, initialTitle:^(youtube.com_/)$ # Youtube
|
||||||
|
|||||||
@@ -1,10 +0,0 @@
|
|||||||
# Fixing popup size issue
|
|
||||||
windowrule = size 50% 50%, class:(.*jetbrains.*)$, title:^$,floating:1
|
|
||||||
|
|
||||||
# Fix tooltips (always have a title of `win.<id>`)
|
|
||||||
windowrule = noinitialfocus, class:^(.*jetbrains.*)$, title:^(win.*)$
|
|
||||||
windowrule = nofocus, class:^(.*jetbrains.*)$, title:^(win.*)$
|
|
||||||
|
|
||||||
# Fix tab dragging (always have a single space character as their title)
|
|
||||||
windowrule = noinitialfocus, class:^(.*jetbrains.*)$, title:^\\s$
|
|
||||||
windowrule = nofocus, class:^(.*jetbrains.*)$, title:^\\s$
|
|
||||||
@@ -1,10 +1,15 @@
|
|||||||
# Floating windows
|
# Float and center settings and previews
|
||||||
windowrule = float, tag:floating-window
|
windowrule = float, class:^(blueberry.py|Impala|Wiremix|org.gnome.NautilusPreviewer|Omarchy|About)$
|
||||||
windowrule = center, tag:floating-window
|
windowrule = center, class:^(blueberry.py|Impala|Wiremix|org.gnome.NautilusPreviewer|Omarchy|About)$
|
||||||
windowrule = size 800 600, tag:floating-window
|
windowrule = size 800 600, class:^(blueberry.py|Impala|Wiremix|org.gnome.NautilusPreviewer|com.gabm.satty)$
|
||||||
|
windowrule = size 620 470, class:Omarchy
|
||||||
|
windowrule = size 700 520, class:About
|
||||||
|
|
||||||
windowrule = tag +floating-window, class:(blueberry.py|Impala|Wiremix|org.gnome.NautilusPreviewer|com.gabm.satty|Omarchy|About|TUI.float)
|
# Float and center file pickers
|
||||||
windowrule = tag +floating-window, class:(xdg-desktop-portal-gtk|sublime_text), title:^(Open.*Files?|Save.*Files?|All Files|Save)
|
windowrule = tag +picker, class:(xdg-desktop-portal-gtk|sublime_text)
|
||||||
|
windowrule = float, tag:picker, title:^(Open.*Files?|Save.*Files?|All Files|Save)
|
||||||
|
windowrule = center, tag:picker, title:^(Open.*Files?|Save.*Files?|All Files|Save)
|
||||||
|
windowrule = size 800 600, tag:picker
|
||||||
|
|
||||||
# Fullscreen screensaver
|
# Fullscreen screensaver
|
||||||
windowrule = fullscreen, class:Screensaver
|
windowrule = fullscreen, class:Screensaver
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
# Application-specific animation
|
# Application-sepcific animation
|
||||||
layerrule = noanim, walker
|
layerrule = noanim, walker
|
||||||
|
|||||||
@@ -4,9 +4,6 @@ exec-once = uwsm app -- waybar
|
|||||||
exec-once = uwsm app -- fcitx5
|
exec-once = uwsm app -- fcitx5
|
||||||
exec-once = uwsm app -- swaybg -i ~/.config/omarchy/current/background -m fill
|
exec-once = uwsm app -- swaybg -i ~/.config/omarchy/current/background -m fill
|
||||||
exec-once = uwsm app -- swayosd-server
|
exec-once = uwsm app -- swayosd-server
|
||||||
|
exec-once = uwsm app -- walker --gapplication-service
|
||||||
exec-once = /usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1
|
exec-once = /usr/lib/polkit-gnome/polkit-gnome-authentication-agent-1
|
||||||
exec-once = wl-clip-persist --clipboard regular --all-mime-type-regex '^(?!x-kde-passwordManagerHint).+'
|
exec-once = wl-clip-persist --clipboard regular --all-mime-type-regex '^(?!x-kde-passwordManagerHint).+'
|
||||||
|
|
||||||
# FIXME: Reenable the walker service once the memory leak has been fixed
|
|
||||||
# See https://github.com/basecamp/omarchy/issues/698
|
|
||||||
# exec-once = uwsm app -- walker --gapplication-service
|
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ bindd = SUPER, T, Top, exec, $terminal -e btop
|
|||||||
bindd = SUPER, D, Lazy Docker, exec, $terminal -e lazydocker
|
bindd = SUPER, D, Lazy Docker, exec, $terminal -e lazydocker
|
||||||
bindd = SUPER, G, Messenger, exec, $messenger
|
bindd = SUPER, G, Messenger, exec, $messenger
|
||||||
bindd = SUPER, O, Obsidian, exec, obsidian -disable-gpu
|
bindd = SUPER, O, Obsidian, exec, obsidian -disable-gpu
|
||||||
bindd = SUPER, slash, Password manager, exec, $passwordManager
|
bindd = SUPER, slash, Pasword manager, exec, $passwordManager
|
||||||
|
|
||||||
source = ~/.local/share/omarchy/default/hypr/bindings/media.conf
|
source = ~/.local/share/omarchy/default/hypr/bindings/media.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/bindings/tiling.conf
|
source = ~/.local/share/omarchy/default/hypr/bindings/tiling.conf
|
||||||
|
|||||||
@@ -9,17 +9,8 @@ bindeld = ,XF86AudioMicMute, Mute microphone, exec, $osdclient --input-volume mu
|
|||||||
bindeld = ,XF86MonBrightnessUp, Brightness up, exec, $osdclient --brightness raise
|
bindeld = ,XF86MonBrightnessUp, Brightness up, exec, $osdclient --brightness raise
|
||||||
bindeld = ,XF86MonBrightnessDown, Brightness down, exec, $osdclient --brightness lower
|
bindeld = ,XF86MonBrightnessDown, Brightness down, exec, $osdclient --brightness lower
|
||||||
|
|
||||||
# Precise 1% multimedia adjustments with Alt modifier
|
|
||||||
bindeld = ALT, XF86AudioRaiseVolume, Volume up precise, exec, $osdclient --output-volume +1
|
|
||||||
bindeld = ALT, XF86AudioLowerVolume, Volume down precise, exec, $osdclient --output-volume -1
|
|
||||||
bindeld = ALT, XF86MonBrightnessUp, Brightness up precise, exec, $osdclient --brightness +1
|
|
||||||
bindeld = ALT, XF86MonBrightnessDown, Brightness down precise, exec, $osdclient --brightness -1
|
|
||||||
|
|
||||||
# Requires playerctl
|
# Requires playerctl
|
||||||
bindld = , XF86AudioNext, Next track, exec, $osdclient --playerctl next
|
bindld = , XF86AudioNext, Next track, exec, $osdclient --playerctl next
|
||||||
bindld = , XF86AudioPause, Pause, exec, $osdclient --playerctl play-pause
|
bindld = , XF86AudioPause, Pause, exec, $osdclient --playerctl play-pause
|
||||||
bindld = , XF86AudioPlay, Play, exec, $osdclient --playerctl play-pause
|
bindld = , XF86AudioPlay, Play, exec, $osdclient --playerctl play-pause
|
||||||
bindld = , XF86AudioPrev, Previous track, exec, $osdclient --playerctl previous
|
bindld = , XF86AudioPrev, Previous track, exec, $osdclient --playerctl previous
|
||||||
|
|
||||||
# Switch audio output with Super + Mute
|
|
||||||
bindld = SUPER, XF86AudioMute, Switch audio output, exec, omarchy-cmd-audio-switch
|
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
# Close windows
|
# Close window
|
||||||
bindd = SUPER, W, Close active window, killactive,
|
bindd = SUPER, W, Close active window, killactive,
|
||||||
bindd = CTRL ALT, DELETE, Close all Windows, exec, omarchy-cmd-close-all-windows
|
|
||||||
|
|
||||||
# Control tiling
|
# Control tiling
|
||||||
bindd = SUPER, J, Toggle split, togglesplit, # dwindle
|
bindd = SUPER, J, Toggle split, togglesplit, # dwindle
|
||||||
@@ -38,10 +37,6 @@ bindd = SUPER SHIFT, code:17, Move window to workspace 8, movetoworkspace, 8
|
|||||||
bindd = SUPER SHIFT, code:18, Move window to workspace 9, movetoworkspace, 9
|
bindd = SUPER SHIFT, code:18, Move window to workspace 9, movetoworkspace, 9
|
||||||
bindd = SUPER SHIFT, code:19, Move window to workspace 10, movetoworkspace, 10
|
bindd = SUPER SHIFT, code:19, Move window to workspace 10, movetoworkspace, 10
|
||||||
|
|
||||||
# Tab between workspaces
|
|
||||||
bind = SUPER, TAB, workspace, e+1
|
|
||||||
bind = SUPER SHIFT, TAB, workspace, e-1
|
|
||||||
|
|
||||||
# Swap active window with the one next to it with SUPER + SHIFT + arrow keys
|
# Swap active window with the one next to it with SUPER + SHIFT + arrow keys
|
||||||
bindd = SUPER SHIFT, left, Swap window to the left, swapwindow, l
|
bindd = SUPER SHIFT, left, Swap window to the left, swapwindow, l
|
||||||
bindd = SUPER SHIFT, right, Swap window to the right, swapwindow, r
|
bindd = SUPER SHIFT, right, Swap window to the right, swapwindow, r
|
||||||
@@ -50,9 +45,7 @@ bindd = SUPER SHIFT, down, Swap window down, swapwindow, d
|
|||||||
|
|
||||||
# Cycle through applications on active workspace
|
# Cycle through applications on active workspace
|
||||||
bindd = ALT, Tab, Cycle to next window, cyclenext
|
bindd = ALT, Tab, Cycle to next window, cyclenext
|
||||||
bindd = ALT SHIFT, Tab, Cycle to prev window, cyclenext, prev
|
|
||||||
bindd = ALT, Tab, Reveal active window on top, bringactivetotop
|
bindd = ALT, Tab, Reveal active window on top, bringactivetotop
|
||||||
bindd = ALT SHIFT, Tab, Reveal active window on top, bringactivetotop
|
|
||||||
|
|
||||||
# Resize active window
|
# Resize active window
|
||||||
bindd = SUPER, minus, Expand window left, resizeactive, -100 0
|
bindd = SUPER, minus, Expand window left, resizeactive, -100 0
|
||||||
|
|||||||
@@ -1,9 +1,7 @@
|
|||||||
# Menus
|
# Menus
|
||||||
bindd = SUPER, SPACE, Launch apps, exec, walker -p "Start…"
|
bindd = SUPER, SPACE, Launch apps, exec, walker -p "Start…"
|
||||||
bindd = SUPER CTRL, E, Show clipboard, exec, walker -m Emojis
|
|
||||||
bindd = SUPER ALT, SPACE, Omarchy menu, exec, omarchy-menu
|
bindd = SUPER ALT, SPACE, Omarchy menu, exec, omarchy-menu
|
||||||
bindd = SUPER, ESCAPE, Power menu, exec, omarchy-menu system
|
bindd = SUPER, ESCAPE, Power menu, exec, omarchy-menu system
|
||||||
bindld = , XF86PowerOff, Power menu, exec, omarchy-menu system
|
|
||||||
bindd = SUPER, K, Show key bindings, exec, omarchy-menu-keybindings
|
bindd = SUPER, K, Show key bindings, exec, omarchy-menu-keybindings
|
||||||
|
|
||||||
# Aesthetics
|
# Aesthetics
|
||||||
|
|||||||
4
default/systemd/resolved.conf
Normal file
4
default/systemd/resolved.conf
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
[Resolve]
|
||||||
|
DNS=1.1.1.1
|
||||||
|
FallbackDNS=8.8.8.8
|
||||||
|
DNSStubListener=yes
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
@import url("file://~/.config/omarchy/current/theme/walker.css");
|
||||||
|
|
||||||
/* Reset all elements */
|
/* Reset all elements */
|
||||||
#window,
|
#window,
|
||||||
#box,
|
#box,
|
||||||
@@ -166,4 +168,3 @@ scrollbar {
|
|||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@import url("file://~/.config/omarchy/current/theme/walker.css");
|
|
||||||
|
|||||||
26
icon.txt
26
icon.txt
@@ -1,26 +0,0 @@
|
|||||||
██████████████████████████████████████████████████████
|
|
||||||
██████████████████████████████████████████████████████
|
|
||||||
████ ████ ████
|
|
||||||
████ ████ ████
|
|
||||||
████ █████████████████████ ████████ ████
|
|
||||||
████ █████████████████████ ████████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████████████ ████ ████
|
|
||||||
████████████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ████ ████ ████
|
|
||||||
████ ██████████████████████████████████████ ████
|
|
||||||
████ ██████████████████████████████████████ ████
|
|
||||||
████ ████ ████
|
|
||||||
████ ████ ████
|
|
||||||
█████████████████████████████ ████████████████████
|
|
||||||
█████████████████████████████ ████████████████████
|
|
||||||
70
install.sh
70
install.sh
@@ -6,50 +6,49 @@ set -e
|
|||||||
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
||||||
OMARCHY_INSTALL=~/.local/share/omarchy/install
|
OMARCHY_INSTALL=~/.local/share/omarchy/install
|
||||||
|
|
||||||
|
# Give people a chance to retry running the installation
|
||||||
|
catch_errors() {
|
||||||
|
echo -e "\n\e[31mOmarchy installation failed!\e[0m"
|
||||||
|
echo "You can retry by running: bash ~/.local/share/omarchy/install.sh"
|
||||||
|
echo "Get help from the community: https://discord.gg/tXFUdasqhY"
|
||||||
|
}
|
||||||
|
|
||||||
|
trap catch_errors ERR
|
||||||
|
|
||||||
show_logo() {
|
show_logo() {
|
||||||
clear
|
clear
|
||||||
tte -i ~/.local/share/omarchy/logo.txt --frame-rate ${2:-120} ${1:-expand}
|
# tte -i ~/.local/share/omarchy/logo.txt --frame-rate ${2:-120} ${1:-expand}
|
||||||
|
cat <~/.local/share/omarchy/logo.txt
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
|
|
||||||
show_subtext() {
|
show_subtext() {
|
||||||
echo "$1" | tte --frame-rate ${3:-640} ${2:-wipe}
|
echo "$1" # | tte --frame-rate ${3:-640} ${2:-wipe}
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
|
|
||||||
# Install prerequisites
|
# Install prerequisites
|
||||||
source $OMARCHY_INSTALL/preflight/show-env.sh
|
|
||||||
source $OMARCHY_INSTALL/preflight/trap-errors.sh
|
|
||||||
source $OMARCHY_INSTALL/preflight/chroot.sh
|
|
||||||
source $OMARCHY_INSTALL/preflight/mirrorlist.sh
|
|
||||||
source $OMARCHY_INSTALL/preflight/guard.sh
|
source $OMARCHY_INSTALL/preflight/guard.sh
|
||||||
source $OMARCHY_INSTALL/preflight/aur.sh
|
source $OMARCHY_INSTALL/preflight/aur.sh
|
||||||
|
source $OMARCHY_INSTALL/preflight/presentation.sh
|
||||||
source $OMARCHY_INSTALL/preflight/migrations.sh
|
source $OMARCHY_INSTALL/preflight/migrations.sh
|
||||||
|
|
||||||
# Configuration
|
# Configuration
|
||||||
|
show_logo beams 240
|
||||||
|
show_subtext "Let's install Omarchy! [1/5]"
|
||||||
|
source $OMARCHY_INSTALL/config/identification.sh
|
||||||
source $OMARCHY_INSTALL/config/config.sh
|
source $OMARCHY_INSTALL/config/config.sh
|
||||||
source $OMARCHY_INSTALL/config/branding.sh
|
|
||||||
source $OMARCHY_INSTALL/config/network.sh
|
|
||||||
source $OMARCHY_INSTALL/config/power.sh
|
|
||||||
source $OMARCHY_INSTALL/config/git.sh
|
|
||||||
source $OMARCHY_INSTALL/config/gpg.sh
|
|
||||||
source $OMARCHY_INSTALL/config/usb-autosuspend.sh
|
|
||||||
source $OMARCHY_INSTALL/config/timezones.sh
|
|
||||||
source $OMARCHY_INSTALL/config/nvidia.sh
|
|
||||||
source $OMARCHY_INSTALL/config/increase-sudo-tries.sh
|
|
||||||
source $OMARCHY_INSTALL/config/increase-lockout-limit.sh
|
|
||||||
source $OMARCHY_INSTALL/config/ignore-power-button.sh
|
|
||||||
source $OMARCHY_INSTALL/config/ssh-flakiness.sh
|
|
||||||
source $OMARCHY_INSTALL/config/detect-keyboard-layout.sh
|
source $OMARCHY_INSTALL/config/detect-keyboard-layout.sh
|
||||||
source $OMARCHY_INSTALL/config/fix-fkeys.sh
|
source $OMARCHY_INSTALL/config/fix-fkeys.sh
|
||||||
source $OMARCHY_INSTALL/config/xcompose.sh
|
source $OMARCHY_INSTALL/config/network.sh
|
||||||
|
source $OMARCHY_INSTALL/config/power.sh
|
||||||
# Login
|
source $OMARCHY_INSTALL/config/timezones.sh
|
||||||
source $OMARCHY_INSTALL/login/plymouth.sh
|
source $OMARCHY_INSTALL/config/login.sh
|
||||||
source $OMARCHY_INSTALL/login/limine-snapper.sh
|
source $OMARCHY_INSTALL/config/nvidia.sh
|
||||||
source $OMARCHY_INSTALL/login/alt-bootloaders.sh
|
|
||||||
|
|
||||||
# Development
|
# Development
|
||||||
|
show_logo decrypt 920
|
||||||
|
show_subtext "Installing terminal tools [2/5]"
|
||||||
source $OMARCHY_INSTALL/development/terminal.sh
|
source $OMARCHY_INSTALL/development/terminal.sh
|
||||||
source $OMARCHY_INSTALL/development/development.sh
|
source $OMARCHY_INSTALL/development/development.sh
|
||||||
source $OMARCHY_INSTALL/development/nvim.sh
|
source $OMARCHY_INSTALL/development/nvim.sh
|
||||||
@@ -58,6 +57,8 @@ source $OMARCHY_INSTALL/development/docker.sh
|
|||||||
source $OMARCHY_INSTALL/development/firewall.sh
|
source $OMARCHY_INSTALL/development/firewall.sh
|
||||||
|
|
||||||
# Desktop
|
# Desktop
|
||||||
|
show_logo slice 60
|
||||||
|
show_subtext "Installing desktop tools [3/5]"
|
||||||
source $OMARCHY_INSTALL/desktop/desktop.sh
|
source $OMARCHY_INSTALL/desktop/desktop.sh
|
||||||
source $OMARCHY_INSTALL/desktop/hyprlandia.sh
|
source $OMARCHY_INSTALL/desktop/hyprlandia.sh
|
||||||
source $OMARCHY_INSTALL/desktop/theme.sh
|
source $OMARCHY_INSTALL/desktop/theme.sh
|
||||||
@@ -67,27 +68,20 @@ source $OMARCHY_INSTALL/desktop/fonts.sh
|
|||||||
source $OMARCHY_INSTALL/desktop/printer.sh
|
source $OMARCHY_INSTALL/desktop/printer.sh
|
||||||
|
|
||||||
# Apps
|
# Apps
|
||||||
|
show_logo expand
|
||||||
|
show_subtext "Installing default applications [4/5]"
|
||||||
source $OMARCHY_INSTALL/apps/webapps.sh
|
source $OMARCHY_INSTALL/apps/webapps.sh
|
||||||
source $OMARCHY_INSTALL/apps/tuis.sh
|
|
||||||
source $OMARCHY_INSTALL/apps/xtras.sh
|
source $OMARCHY_INSTALL/apps/xtras.sh
|
||||||
source $OMARCHY_INSTALL/apps/mimetypes.sh
|
source $OMARCHY_INSTALL/apps/mimetypes.sh
|
||||||
|
|
||||||
# Updates
|
# Updates
|
||||||
|
show_logo highlight
|
||||||
|
show_subtext "Updating system packages [5/5]"
|
||||||
sudo updatedb
|
sudo updatedb
|
||||||
|
yay -Syu --noconfirm --ignore uwsm
|
||||||
# Update system packages if we have a network connection
|
|
||||||
if ping -c5 omarchy.org &>/dev/null; then
|
|
||||||
yay -Syu --noconfirm
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Reboot
|
# Reboot
|
||||||
show_logo laseretch 920
|
show_logo laseretch 920
|
||||||
show_subtext "You're done! So we're ready to reboot now..."
|
show_subtext "You're done! So we'll be rebooting now..."
|
||||||
|
sleep 2
|
||||||
if sudo test -f /etc/sudoers.d/99-omarchy-installer; then
|
|
||||||
sudo rm -f /etc/sudoers.d/99-omarchy-installer &>/dev/null
|
|
||||||
echo -e "\nRemember to remove USB installer!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
sleep 5
|
|
||||||
reboot
|
reboot
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if [ -z "$OMARCHY_BARE" ]; then
|
|
||||||
omarchy-tui-install "Disk Usage" "bash -c 'dust -r; read -n 1 -s'" float https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/qdirstat.png
|
|
||||||
omarchy-tui-install "Docker" "lazydocker" tile https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/docker.png
|
|
||||||
fi
|
|
||||||
@@ -13,5 +13,4 @@ if [ -z "$OMARCHY_BARE" ]; then
|
|||||||
omarchy-webapp-install "X" https://x.com/ https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/x-light.png
|
omarchy-webapp-install "X" https://x.com/ https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/x-light.png
|
||||||
omarchy-webapp-install "Figma" https://figma.com/ https://www.veryicon.com/download/png/application/app-icon-7/figma-1?s=256
|
omarchy-webapp-install "Figma" https://figma.com/ https://www.veryicon.com/download/png/application/app-icon-7/figma-1?s=256
|
||||||
omarchy-webapp-install "Discord" https://discord.com/channels/@me https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/discord.png
|
omarchy-webapp-install "Discord" https://discord.com/channels/@me https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/discord.png
|
||||||
omarchy-webapp-install "Zoom" https://app.zoom.us/wc/home https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/zoom.png
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ if [ -z "$OMARCHY_BARE" ]; then
|
|||||||
xournalpp localsend-bin
|
xournalpp localsend-bin
|
||||||
|
|
||||||
# Packages known to be flaky or having key signing issues are run one-by-one
|
# Packages known to be flaky or having key signing issues are run one-by-one
|
||||||
for pkg in typora spotify pinta; do
|
for pkg in pinta typora spotify zoom; do
|
||||||
yay -S --noconfirm --needed "$pkg" ||
|
yay -S --noconfirm --needed "$pkg" ||
|
||||||
echo -e "\e[31mFailed to install $pkg. Continuing without!\e[0m"
|
echo -e "\e[31mFailed to install $pkg. Continuing without!\e[0m"
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
mkdir -p ~/.config/omarchy/branding
|
|
||||||
cp ~/.local/share/omarchy/icon.txt ~/.config/omarchy/branding/about.txt
|
|
||||||
cp ~/.local/share/omarchy/logo.txt ~/.config/omarchy/branding/screensaver.txt
|
|
||||||
@@ -1,7 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Copy over Omarchy configs
|
# Copy over Omarchy configs
|
||||||
mkdir -p ~/.config
|
|
||||||
cp -R ~/.local/share/omarchy/config/* ~/.config/
|
cp -R ~/.local/share/omarchy/config/* ~/.config/
|
||||||
|
|
||||||
# Use default bashrc from Omarchy
|
# Use default bashrc from Omarchy
|
||||||
@@ -15,3 +14,46 @@ if [ -n "$OMARCHY_BARE" ]; then
|
|||||||
mkdir -p ~/.local/state/omarchy
|
mkdir -p ~/.local/state/omarchy
|
||||||
touch ~/.local/state/omarchy/bare.mode
|
touch ~/.local/state/omarchy/bare.mode
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Setup GPG configuration with multiple keyservers for better reliability
|
||||||
|
sudo mkdir -p /etc/gnupg
|
||||||
|
sudo cp ~/.local/share/omarchy/default/gpg/dirmngr.conf /etc/gnupg/
|
||||||
|
sudo chmod 644 /etc/gnupg/dirmngr.conf
|
||||||
|
sudo gpgconf --kill dirmngr || true
|
||||||
|
sudo gpgconf --launch dirmngr || true
|
||||||
|
|
||||||
|
# Increase lockout limit to 10 and decrease timeout to 2 minutes
|
||||||
|
sudo sed -i 's|^\(auth\s\+required\s\+pam_faillock.so\)\s\+preauth.*$|\1 preauth silent deny=10 unlock_time=120|' "/etc/pam.d/system-auth"
|
||||||
|
sudo sed -i 's|^\(auth\s\+\[default=die\]\s\+pam_faillock.so\)\s\+authfail.*$|\1 authfail deny=10 unlock_time=120|' "/etc/pam.d/system-auth"
|
||||||
|
|
||||||
|
# Set Cloudflare as primary DNS (with Google as backup)
|
||||||
|
sudo cp ~/.local/share/omarchy/default/systemd/resolved.conf /etc/systemd/
|
||||||
|
|
||||||
|
# Solve common flakiness with SSH and Tailscale performance
|
||||||
|
echo "net.ipv4.tcp_mtu_probing=2" | sudo tee -a /etc/sysctl.d/99-sysctl.conf
|
||||||
|
|
||||||
|
# Set common git aliases
|
||||||
|
git config --global alias.co checkout
|
||||||
|
git config --global alias.br branch
|
||||||
|
git config --global alias.ci commit
|
||||||
|
git config --global alias.st status
|
||||||
|
git config --global pull.rebase true
|
||||||
|
git config --global init.defaultBranch master
|
||||||
|
|
||||||
|
# Set identification from install inputs
|
||||||
|
if [[ -n "${OMARCHY_USER_NAME//[[:space:]]/}" ]]; then
|
||||||
|
git config --global user.name "$OMARCHY_USER_NAME"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n "${OMARCHY_USER_EMAIL//[[:space:]]/}" ]]; then
|
||||||
|
git config --global user.email "$OMARCHY_USER_EMAIL"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set default XCompose that is triggered with CapsLock
|
||||||
|
tee ~/.XCompose >/dev/null <<EOF
|
||||||
|
include "%H/.local/share/omarchy/default/xcompose"
|
||||||
|
|
||||||
|
# Identification
|
||||||
|
<Multi_key> <space> <n> : "$OMARCHY_USER_NAME"
|
||||||
|
<Multi_key> <space> <e> : "$OMARCHY_USER_EMAIL"
|
||||||
|
EOF
|
||||||
|
|||||||
@@ -2,4 +2,7 @@
|
|||||||
|
|
||||||
if [[ ! -f /etc/modprobe.d/hid_apple.conf ]]; then
|
if [[ ! -f /etc/modprobe.d/hid_apple.conf ]]; then
|
||||||
echo "options hid_apple fnmode=2" | sudo tee /etc/modprobe.d/hid_apple.conf
|
echo "options hid_apple fnmode=2" | sudo tee /etc/modprobe.d/hid_apple.conf
|
||||||
|
|
||||||
|
# Rely on install/login.sh to do the rebuild
|
||||||
|
# sudo mkinitcpio -P
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,18 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Set common git aliases
|
|
||||||
git config --global alias.co checkout
|
|
||||||
git config --global alias.br branch
|
|
||||||
git config --global alias.ci commit
|
|
||||||
git config --global alias.st status
|
|
||||||
git config --global pull.rebase true
|
|
||||||
git config --global init.defaultBranch master
|
|
||||||
|
|
||||||
# Set identification from install inputs
|
|
||||||
if [[ -n "${OMARCHY_USER_NAME//[[:space:]]/}" ]]; then
|
|
||||||
git config --global user.name "$OMARCHY_USER_NAME"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -n "${OMARCHY_USER_EMAIL//[[:space:]]/}" ]]; then
|
|
||||||
git config --global user.email "$OMARCHY_USER_EMAIL"
|
|
||||||
fi
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Setup GPG configuration with multiple keyservers for better reliability
|
|
||||||
sudo mkdir -p /etc/gnupg
|
|
||||||
sudo cp ~/.local/share/omarchy/default/gpg/dirmngr.conf /etc/gnupg/
|
|
||||||
sudo chmod 644 /etc/gnupg/dirmngr.conf
|
|
||||||
sudo gpgconf --kill dirmngr || true
|
|
||||||
sudo gpgconf --launch dirmngr || true
|
|
||||||
4
install/config/identification.sh
Normal file
4
install/config/identification.sh
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
export OMARCHY_USER_NAME=$(gum input --placeholder "Enter full name" --prompt "Name> ")
|
||||||
|
export OMARCHY_USER_EMAIL=$(gum input --placeholder "Enter email address" --prompt "Email> ")
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Disable shutting system down on power button to bind it to power menu afterwards
|
|
||||||
sudo sed -i 's/.*HandlePowerKey=.*/HandlePowerKey=ignore/' /etc/systemd/logind.conf
|
|
||||||
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Increase lockout limit to 10 and decrease timeout to 2 minutes
|
|
||||||
sudo sed -i 's|^\(auth\s\+required\s\+pam_faillock.so\)\s\+preauth.*$|\1 preauth silent deny=10 unlock_time=120|' "/etc/pam.d/system-auth"
|
|
||||||
sudo sed -i 's|^\(auth\s\+\[default=die\]\s\+pam_faillock.so\)\s\+authfail.*$|\1 authfail deny=10 unlock_time=120|' "/etc/pam.d/system-auth"
|
|
||||||
@@ -1,4 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
echo "Defaults passwd_tries=10" | sudo tee /etc/sudoers.d/passwd-tries
|
|
||||||
sudo chmod 440 /etc/sudoers.d/passwd-tries
|
|
||||||
@@ -2,13 +2,127 @@
|
|||||||
|
|
||||||
# Hyprland launched via UWSM and login directly as user, rely on disk encryption + hyprlock for security
|
# Hyprland launched via UWSM and login directly as user, rely on disk encryption + hyprlock for security
|
||||||
if ! command -v uwsm &>/dev/null || ! command -v plymouth &>/dev/null; then
|
if ! command -v uwsm &>/dev/null || ! command -v plymouth &>/dev/null; then
|
||||||
yay -S --noconfirm --needed plymouth uwsm
|
sudo pacman -U --noconfirm https://archive.archlinux.org/packages/u/uwsm/uwsm-0.23.0-1-any.pkg.tar.zst
|
||||||
|
yay -S --noconfirm --needed plymouth
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# ==============================================================================
|
# ==============================================================================
|
||||||
# PLYMOUTH SETUP
|
# PLYMOUTH SETUP
|
||||||
# ==============================================================================
|
# ==============================================================================
|
||||||
|
|
||||||
|
if ! grep -Eq '^HOOKS=.*plymouth' /etc/mkinitcpio.conf; then
|
||||||
|
# Backup original mkinitcpio.conf just in case
|
||||||
|
backup_timestamp=$(date +"%Y%m%d%H%M%S")
|
||||||
|
sudo cp /etc/mkinitcpio.conf "/etc/mkinitcpio.conf.bak.${backup_timestamp}"
|
||||||
|
|
||||||
|
# Add plymouth to HOOKS array after 'base udev' or 'base systemd'
|
||||||
|
if grep "^HOOKS=" /etc/mkinitcpio.conf | grep -q "base systemd"; then
|
||||||
|
sudo sed -i '/^HOOKS=/s/base systemd/base systemd plymouth/' /etc/mkinitcpio.conf
|
||||||
|
elif grep "^HOOKS=" /etc/mkinitcpio.conf | grep -q "base udev"; then
|
||||||
|
sudo sed -i '/^HOOKS=/s/base udev/base udev plymouth/' /etc/mkinitcpio.conf
|
||||||
|
else
|
||||||
|
echo "Couldn't add the Plymouth hook"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Regenerate initramfs
|
||||||
|
sudo mkinitcpio -P
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Add kernel parameters for Plymouth
|
||||||
|
if [ -d "/boot/loader/entries" ]; then # systemd-boot
|
||||||
|
echo "Detected systemd-boot"
|
||||||
|
|
||||||
|
for entry in /boot/loader/entries/*.conf; do
|
||||||
|
if [ -f "$entry" ]; then
|
||||||
|
# Skip fallback entries
|
||||||
|
if [[ "$(basename "$entry")" == *"fallback"* ]]; then
|
||||||
|
echo "Skipped: $(basename "$entry") (fallback entry)"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Skip if splash it already present for some reason
|
||||||
|
if ! grep -q "splash" "$entry"; then
|
||||||
|
sudo sed -i '/^options/ s/$/ splash quiet/' "$entry"
|
||||||
|
else
|
||||||
|
echo "Skipped: $(basename "$entry") (splash already present)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
elif [ -f "/etc/default/grub" ]; then # Grub
|
||||||
|
echo "Detected grub"
|
||||||
|
|
||||||
|
# Backup GRUB config before modifying
|
||||||
|
backup_timestamp=$(date +"%Y%m%d%H%M%S")
|
||||||
|
sudo cp /etc/default/grub "/etc/default/grub.bak.${backup_timestamp}"
|
||||||
|
|
||||||
|
# Check if splash is already in GRUB_CMDLINE_LINUX_DEFAULT
|
||||||
|
if ! grep -q "GRUB_CMDLINE_LINUX_DEFAULT.*splash" /etc/default/grub; then
|
||||||
|
# Get current GRUB_CMDLINE_LINUX_DEFAULT value
|
||||||
|
current_cmdline=$(grep "^GRUB_CMDLINE_LINUX_DEFAULT=" /etc/default/grub | cut -d'"' -f2)
|
||||||
|
|
||||||
|
# Add splash and quiet if not present
|
||||||
|
new_cmdline="$current_cmdline"
|
||||||
|
if [[ ! "$current_cmdline" =~ splash ]]; then
|
||||||
|
new_cmdline="$new_cmdline splash"
|
||||||
|
fi
|
||||||
|
if [[ ! "$current_cmdline" =~ quiet ]]; then
|
||||||
|
new_cmdline="$new_cmdline quiet"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Trim any leading/trailing spaces
|
||||||
|
new_cmdline=$(echo "$new_cmdline" | xargs)
|
||||||
|
|
||||||
|
sudo sed -i "s/^GRUB_CMDLINE_LINUX_DEFAULT=\".*\"/GRUB_CMDLINE_LINUX_DEFAULT=\"$new_cmdline\"/" /etc/default/grub
|
||||||
|
|
||||||
|
# Regenerate grub config
|
||||||
|
sudo grub-mkconfig -o /boot/grub/grub.cfg
|
||||||
|
else
|
||||||
|
echo "GRUB already configured with splash kernel parameters"
|
||||||
|
fi
|
||||||
|
elif [ -d "/etc/cmdline.d" ]; then # UKI
|
||||||
|
echo "Detected a UKI setup"
|
||||||
|
# Relying on mkinitcpio to assemble a UKI
|
||||||
|
# https://wiki.archlinux.org/title/Unified_kernel_image
|
||||||
|
if ! grep -q splash /etc/cmdline.d/*.conf; then
|
||||||
|
# Need splash, create the omarchy file
|
||||||
|
echo "splash" | sudo tee -a /etc/cmdline.d/omarchy.conf
|
||||||
|
fi
|
||||||
|
if ! grep -q quiet /etc/cmdline.d/*.conf; then
|
||||||
|
# Need quiet, create or append the omarchy file
|
||||||
|
echo "quiet" | sudo tee -a /etc/cmdline.d/omarchy.conf
|
||||||
|
fi
|
||||||
|
elif [ -f "/etc/kernel/cmdline" ]; then # UKI Alternate
|
||||||
|
# Alternate UKI kernel cmdline location
|
||||||
|
echo "Detected a UKI setup"
|
||||||
|
|
||||||
|
# Backup kernel cmdline config before modifying
|
||||||
|
backup_timestamp=$(date +"%Y%m%d%H%M%S")
|
||||||
|
sudo cp /etc/kernel/cmdline "/etc/kernel/cmdline.bak.${backup_timestamp}"
|
||||||
|
|
||||||
|
current_cmdline=$(cat /etc/kernel/cmdline)
|
||||||
|
|
||||||
|
# Add splash and quiet if not present
|
||||||
|
new_cmdline="$current_cmdline"
|
||||||
|
if [[ ! "$current_cmdline" =~ splash ]]; then
|
||||||
|
new_cmdline="$new_cmdline splash"
|
||||||
|
fi
|
||||||
|
if [[ ! "$current_cmdline" =~ quiet ]]; then
|
||||||
|
new_cmdline="$new_cmdline quiet"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Trim any leading/trailing spaces
|
||||||
|
new_cmdline=$(echo "$new_cmdline" | xargs)
|
||||||
|
|
||||||
|
# Write new file
|
||||||
|
echo $new_cmdline | sudo tee /etc/kernel/cmdline
|
||||||
|
else
|
||||||
|
echo ""
|
||||||
|
echo " None of systemd-boot, GRUB, or UKI detected. Please manually add these kernel parameters:"
|
||||||
|
echo " - splash (to see the graphical splash screen)"
|
||||||
|
echo " - quiet (for silent boot)"
|
||||||
|
echo ""
|
||||||
|
fi
|
||||||
|
|
||||||
if [ "$(plymouth-set-default-theme)" != "omarchy" ]; then
|
if [ "$(plymouth-set-default-theme)" != "omarchy" ]; then
|
||||||
sudo cp -r "$HOME/.local/share/omarchy/default/plymouth" /usr/share/plymouth/themes/omarchy/
|
sudo cp -r "$HOME/.local/share/omarchy/default/plymouth" /usr/share/plymouth/themes/omarchy/
|
||||||
sudo plymouth-set-default-theme -R omarchy
|
sudo plymouth-set-default-theme -R omarchy
|
||||||
@@ -113,8 +227,6 @@ Type=simple
|
|||||||
ExecStart=/usr/local/bin/seamless-login uwsm start -- hyprland.desktop
|
ExecStart=/usr/local/bin/seamless-login uwsm start -- hyprland.desktop
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=2
|
RestartSec=2
|
||||||
StartLimitIntervalSec=30
|
|
||||||
StartLimitBurst=2
|
|
||||||
User=$USER
|
User=$USER
|
||||||
TTYPath=/dev/tty1
|
TTYPath=/dev/tty1
|
||||||
TTYReset=yes
|
TTYReset=yes
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
# This can happen if archinstall used ethernet
|
# This can happen if archinstall used ethernet
|
||||||
if ! command -v iwctl &>/dev/null; then
|
if ! command -v iwctl &>/dev/null; then
|
||||||
yay -S --noconfirm --needed iwd
|
yay -S --noconfirm --needed iwd
|
||||||
chrootable_systemctl_enable iwd.service
|
sudo systemctl enable --now iwd.service
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Prevent systemd-networkd-wait-online timeout on boot
|
# Prevent systemd-networkd-wait-online timeout on boot
|
||||||
|
|||||||
@@ -2,18 +2,15 @@
|
|||||||
|
|
||||||
# Setting the performance profile can make a big difference. By default, most systems seem to start in balanced mode,
|
# Setting the performance profile can make a big difference. By default, most systems seem to start in balanced mode,
|
||||||
# even if they're not running off a battery. So let's make sure that's changed to performance.
|
# even if they're not running off a battery. So let's make sure that's changed to performance.
|
||||||
yay -S --noconfirm python-gobject power-profiles-daemon
|
yay -S --noconfirm power-profiles-daemon
|
||||||
|
|
||||||
# FIXME: Can't set powerprofilesctl during CHROOT, must do it afterwards
|
if ls /sys/class/power_supply/BAT* &>/dev/null; then
|
||||||
if [ -z "${OMARCHY_CHROOT_INSTALL:-}" ]; then
|
|
||||||
if ls /sys/class/power_supply/BAT* &>/dev/null; then
|
|
||||||
# This computer runs on a battery
|
# This computer runs on a battery
|
||||||
powerprofilesctl set balanced || true
|
powerprofilesctl set balanced || true
|
||||||
|
|
||||||
# Enable battery monitoring timer for low battery notifications
|
# Enable battery monitoring timer for low battery notifications
|
||||||
systemctl --user enable --now omarchy-battery-monitor.timer
|
systemctl --user enable --now omarchy-battery-monitor.timer || true
|
||||||
else
|
else
|
||||||
# This computer runs on power outlet
|
# This computer runs on power outlet
|
||||||
powerprofilesctl set performance || true
|
powerprofilesctl set performance || true
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,4 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Solve common flakiness with SSH
|
|
||||||
echo "net.ipv4.tcp_mtu_probing=1" | sudo tee -a /etc/sysctl.d/99-sysctl.conf
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Disable USB autosuspend to prevent peripheral disconnection issues
|
|
||||||
if [[ ! -f /etc/modprobe.d/disable-usb-autosuspend.conf ]]; then
|
|
||||||
echo "options usbcore autosuspend=-1" | sudo tee /etc/modprobe.d/disable-usb-autosuspend.conf
|
|
||||||
fi
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Set default XCompose that is triggered with CapsLock
|
|
||||||
tee ~/.XCompose >/dev/null <<EOF
|
|
||||||
include "%H/.local/share/omarchy/default/xcompose"
|
|
||||||
|
|
||||||
# Identification
|
|
||||||
<Multi_key> <space> <n> : "$OMARCHY_USER_NAME"
|
|
||||||
<Multi_key> <space> <e> : "$OMARCHY_USER_EMAIL"
|
|
||||||
EOF
|
|
||||||
@@ -4,4 +4,4 @@
|
|||||||
yay -S --noconfirm --needed blueberry
|
yay -S --noconfirm --needed blueberry
|
||||||
|
|
||||||
# Turn on bluetooth by default
|
# Turn on bluetooth by default
|
||||||
chrootable_systemctl_enable bluetooth.service
|
sudo systemctl enable --now bluetooth.service
|
||||||
|
|||||||
@@ -6,10 +6,10 @@ yay -S --noconfirm --needed \
|
|||||||
nautilus sushi ffmpegthumbnailer gvfs-mtp \
|
nautilus sushi ffmpegthumbnailer gvfs-mtp \
|
||||||
slurp satty \
|
slurp satty \
|
||||||
mpv evince imv \
|
mpv evince imv \
|
||||||
omarchy-chromium-bin
|
chromium
|
||||||
|
|
||||||
# Add screen recorder based on GPU
|
# Add screen recorder based on GPU
|
||||||
if lspci | grep -Eqi 'nvidia|intel.*graphics'; then
|
if lspci | grep -qi 'nvidia'; then
|
||||||
yay -S --noconfirm --needed wf-recorder
|
yay -S --noconfirm --needed wf-recorder
|
||||||
else
|
else
|
||||||
yay -S --noconfirm --needed wl-screenrec
|
yay -S --noconfirm --needed wl-screenrec
|
||||||
|
|||||||
@@ -2,10 +2,6 @@
|
|||||||
|
|
||||||
yay -S --noconfirm --needed ttf-font-awesome ttf-cascadia-mono-nerd ttf-ia-writer noto-fonts noto-fonts-emoji
|
yay -S --noconfirm --needed ttf-font-awesome ttf-cascadia-mono-nerd ttf-ia-writer noto-fonts noto-fonts-emoji
|
||||||
|
|
||||||
mkdir -p ~/.local/share/fonts
|
|
||||||
cp ~/.local/share/omarchy/config/omarchy.ttf ~/.local/share/fonts/
|
|
||||||
fc-cache
|
|
||||||
|
|
||||||
if [ -z "$OMARCHY_BARE" ]; then
|
if [ -z "$OMARCHY_BARE" ]; then
|
||||||
yay -S --noconfirm --needed ttf-jetbrains-mono noto-fonts-cjk noto-fonts-extra
|
yay -S --noconfirm --needed ttf-jetbrains-mono noto-fonts-cjk noto-fonts-extra
|
||||||
fi
|
fi
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user