Compare commits
383 Commits
remove-sta
...
v3.0.1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
83ab85799b | ||
|
|
ffe7cd5099 | ||
|
|
cf41ecaaa5 | ||
|
|
9aef0ffab6 | ||
|
|
f6383fd3e9 | ||
|
|
e81994f182 | ||
|
|
7ca60bd590 | ||
|
|
dac34aa5e0 | ||
|
|
81165f1947 | ||
|
|
fc3d1a4af5 | ||
|
|
020a4659ec | ||
|
|
d66909de14 | ||
|
|
0e17c419be | ||
|
|
75f035ddb6 | ||
|
|
a039a0fdae | ||
|
|
9a24ca8a36 | ||
|
|
0b8540e663 | ||
|
|
ebb12f187e | ||
|
|
1669832693 | ||
|
|
80bd5e5979 | ||
|
|
832a33eb93 | ||
|
|
a15ccdd1ed | ||
|
|
6d9ae608e5 | ||
|
|
f6df59c9ed | ||
|
|
1514c5c633 | ||
|
|
d92e13143f | ||
|
|
e14d58fe54 | ||
|
|
f592bca968 | ||
|
|
b5b4dea4ff | ||
|
|
4cda82bc98 | ||
|
|
69ec570aad | ||
|
|
a51c58c20c | ||
|
|
761a51fac0 | ||
|
|
654723aa7f | ||
|
|
b9dfbb8f4c | ||
|
|
eec51b1fb5 | ||
|
|
a1228dac6b | ||
|
|
432ffb508c | ||
|
|
bf0c2cc9a5 | ||
|
|
7e1c88b932 | ||
|
|
c8fa96f382 | ||
|
|
2e4c9d0de8 | ||
|
|
facae82630 | ||
|
|
2719db01f9 | ||
|
|
461f8186f6 | ||
|
|
c5d04e8e9c | ||
|
|
c072715ebe | ||
|
|
55911ebf7d | ||
|
|
d3304c4a88 | ||
|
|
f401c72ea2 | ||
|
|
3986afd0c5 | ||
|
|
415896605e | ||
|
|
1e6ddf55ce | ||
|
|
5582c51676 | ||
|
|
5f56f4ccc7 | ||
|
|
e4ca98301b | ||
|
|
e228a987a8 | ||
|
|
f9edbfe10c | ||
|
|
2cb285c267 | ||
|
|
5be0e4de44 | ||
|
|
5f92574586 | ||
|
|
772a75376e | ||
|
|
d5314cecb7 | ||
|
|
c16766c8b1 | ||
|
|
f8ff57e2af | ||
|
|
8e4487ca41 | ||
|
|
b422281840 | ||
|
|
2e41b2c400 | ||
|
|
55bf2457d4 | ||
|
|
a77264ae99 | ||
|
|
13349180b6 | ||
|
|
445ccdebbf | ||
|
|
27f020af4d | ||
|
|
8920c95586 | ||
|
|
52680f4b3e | ||
|
|
d96322e58a | ||
|
|
0f09febf4d | ||
|
|
d58fe8b4a0 | ||
|
|
4a4ff04741 | ||
|
|
a0e3d86c12 | ||
|
|
2132c684ff | ||
|
|
47bdbec9f1 | ||
|
|
5b0deb90ba | ||
|
|
3e1e466938 | ||
|
|
e018692e5e | ||
|
|
123f970b20 | ||
|
|
9de375648e | ||
|
|
115fcb786d | ||
|
|
23d9b3ae71 | ||
|
|
6bffd1be8e | ||
|
|
a9fe693ed9 | ||
|
|
57bb63b5a3 | ||
|
|
6b3d1d5dc7 | ||
|
|
759003eed9 | ||
|
|
2684322975 | ||
|
|
51607f1978 | ||
|
|
beb2e6b865 | ||
|
|
f14f63b9e6 | ||
|
|
01ce4bb4dd | ||
|
|
02fbe0f305 | ||
|
|
2601311b62 | ||
|
|
dc53c34b6a | ||
|
|
418159bd31 | ||
|
|
10f909fdfc | ||
|
|
5372393211 | ||
|
|
6bf32a082e | ||
|
|
49ca5ee249 | ||
|
|
8651f6d8b0 | ||
|
|
cfbc71c117 | ||
|
|
fc58a79ea5 | ||
|
|
87469f5f43 | ||
|
|
5157932947 | ||
|
|
6599a6eb70 | ||
|
|
d09b6aa42a | ||
|
|
e9754b5460 | ||
|
|
8356358097 | ||
|
|
e57026a067 | ||
|
|
f5cd7a4237 | ||
|
|
381e43d124 | ||
|
|
844091341c | ||
|
|
bdcd78484b | ||
|
|
8c3c93eed1 | ||
|
|
19d85a7710 | ||
|
|
1f5a86ba8e | ||
|
|
a9d9faef24 | ||
|
|
16460b5203 | ||
|
|
bf07883e82 | ||
|
|
a66e8ebebd | ||
|
|
a57060ee31 | ||
|
|
9ca2081742 | ||
|
|
c9bacbe318 | ||
|
|
a0674703f8 | ||
|
|
627b5f4ead | ||
|
|
80767e8686 | ||
|
|
e260d28f43 | ||
|
|
8af2d3257f | ||
|
|
477ec351e7 | ||
|
|
6824ce0d0f | ||
|
|
70c0f70940 | ||
|
|
251997cf54 | ||
|
|
e79cfa76a8 | ||
|
|
a8a907791b | ||
|
|
0dbb81ee9b | ||
|
|
9ecf59dd60 | ||
|
|
78b2f926c8 | ||
|
|
40d7d074a9 | ||
|
|
8a83234298 | ||
|
|
88c7c4c748 | ||
|
|
ddef52c192 | ||
|
|
57ca3d74e5 | ||
|
|
8e67e717a0 | ||
|
|
d5ae9ffa05 | ||
|
|
1de4a49ab0 | ||
|
|
8493054cd0 | ||
|
|
dbd67e6354 | ||
|
|
bc1eee1857 | ||
|
|
9467ff2de3 | ||
|
|
e5a1b99497 | ||
|
|
2f6607c03d | ||
|
|
597c2f58eb | ||
|
|
633b5da37e | ||
|
|
816a660059 | ||
|
|
05d864c8b4 | ||
|
|
ca1ea6ccb8 | ||
|
|
8e601e1fca | ||
|
|
33ebce49b0 | ||
|
|
3d075602cb | ||
|
|
c87c5e5a04 | ||
|
|
8088effe9f | ||
|
|
653b389c9a | ||
|
|
7286bbb674 | ||
|
|
20ef3c821d | ||
|
|
05a5bfc9b4 | ||
|
|
95336e730f | ||
|
|
d5e445b743 | ||
|
|
00fe154e43 | ||
|
|
27742c8f43 | ||
|
|
15c22fb05b | ||
|
|
0d5b41b83a | ||
|
|
8065eb87d8 | ||
|
|
bee90aa121 | ||
|
|
29b1ed6c4e | ||
|
|
7fe02e7d68 | ||
|
|
ec428bc05f | ||
|
|
73bc6159ea | ||
|
|
136a2268ea | ||
|
|
0723059fb3 | ||
|
|
5e5b253dc6 | ||
|
|
9cc185c82d | ||
|
|
ba76610512 | ||
|
|
787d0c75a2 | ||
|
|
b84e687262 | ||
|
|
c499413812 | ||
|
|
c82754d423 | ||
|
|
9ec006a1b2 | ||
|
|
8fd668fbb3 | ||
|
|
25d02e1f3f | ||
|
|
261e1aec08 | ||
|
|
43206dba92 | ||
|
|
6f2f48b412 | ||
|
|
ca7f6ebb3b | ||
|
|
131f934f17 | ||
|
|
91177a6546 | ||
|
|
57a9a1aed0 | ||
|
|
4409f4478b | ||
|
|
6d832cba42 | ||
|
|
8610f4f9da | ||
|
|
4bdbb06cfc | ||
|
|
7a9499eb66 | ||
|
|
a5814e0bfd | ||
|
|
434265cea2 | ||
|
|
6a5f98cb8e | ||
|
|
a4c4b3570c | ||
|
|
849628b288 | ||
|
|
3ea45aa995 | ||
|
|
37d59ca78e | ||
|
|
c6cd49a0aa | ||
|
|
05d5f07cca | ||
|
|
91c8ad36f2 | ||
|
|
521de9794a | ||
|
|
e15caaf713 | ||
|
|
219d2d43e7 | ||
|
|
d68a757b7f | ||
|
|
8dd7c7a94e | ||
|
|
763cbcbc02 | ||
|
|
db8d814071 | ||
|
|
e621e41be2 | ||
|
|
1099a44c77 | ||
|
|
3210ec44f5 | ||
|
|
a44ea9c232 | ||
|
|
f643d97211 | ||
|
|
cc1f49519e | ||
|
|
c0c040f9c0 | ||
|
|
5f94df198f | ||
|
|
fe20e89e0e | ||
|
|
80341b296e | ||
|
|
eeee49e702 | ||
|
|
927abd86ba | ||
|
|
256a27ca8e | ||
|
|
64ec80fb7e | ||
|
|
24b94fde54 | ||
|
|
3b0752820e | ||
|
|
b6896bd58f | ||
|
|
2442f774e4 | ||
|
|
0d62a03ae0 | ||
|
|
7d2759b807 | ||
|
|
792f7827a6 | ||
|
|
9293e2ed17 | ||
|
|
3d49ced97e | ||
|
|
35e169e3cc | ||
|
|
4ee48dd238 | ||
|
|
9e5b4fc871 | ||
|
|
94ad5d4d37 | ||
|
|
0a3ce5c393 | ||
|
|
9f5975b717 | ||
|
|
29c2233399 | ||
|
|
98db40fd0d | ||
|
|
a35055e562 | ||
|
|
3ce7849c89 | ||
|
|
59c70fdd46 | ||
|
|
effae1e7f2 | ||
|
|
a3c5e589f6 | ||
|
|
4f6f92b2cc | ||
|
|
b388d95d4b | ||
|
|
ed3e1f901b | ||
|
|
07c072cf21 | ||
|
|
3266a18897 | ||
|
|
94eeba4849 | ||
|
|
d755de4042 | ||
|
|
ace0fb1cd5 | ||
|
|
2647ea7745 | ||
|
|
defe63a91c | ||
|
|
4e8afd7ad6 | ||
|
|
37699e80e4 | ||
|
|
0b276c4f49 | ||
|
|
8350355a20 | ||
|
|
c5fffc2f1d | ||
|
|
d9c69b8d02 | ||
|
|
3e29949745 | ||
|
|
bb9fbceca2 | ||
|
|
615aa64f01 | ||
|
|
a21ace2ee7 | ||
|
|
f16908d701 | ||
|
|
1fd5966bd9 | ||
|
|
94006b5bb1 | ||
|
|
bc94bb2d6c | ||
|
|
305e799581 | ||
|
|
43ee2cf4e0 | ||
|
|
48e5aa5e91 | ||
|
|
c5290ee970 | ||
|
|
ba4f1f20fc | ||
|
|
005d286f92 | ||
|
|
cd378a55a2 | ||
|
|
4480b3638f | ||
|
|
5f2b6566f1 | ||
|
|
b4d76cecdf | ||
|
|
52dcf01987 | ||
|
|
91dadc905d | ||
|
|
69f5c62f8f | ||
|
|
e3df85ba8c | ||
|
|
3f2e282c46 | ||
|
|
06b15257e2 | ||
|
|
33d6d38332 | ||
|
|
30ad634349 | ||
|
|
6e3d023fee | ||
|
|
950f1f0adc | ||
|
|
126131daa1 | ||
|
|
4e7aa33868 | ||
|
|
a34b7bd131 | ||
|
|
2c751a0920 | ||
|
|
42f7f5f558 | ||
|
|
c56c192b89 | ||
|
|
203dcce898 | ||
|
|
e337c0bbdc | ||
|
|
512df06f36 | ||
|
|
71fe2cbafd | ||
|
|
37d10feba3 | ||
|
|
d94715d59e | ||
|
|
393767cbec | ||
|
|
e9d2a3d3f7 | ||
|
|
2832c59970 | ||
|
|
3882fbf21c | ||
|
|
5fec87d324 | ||
|
|
e5927fc1b2 | ||
|
|
175066ecba | ||
|
|
cf4e1c0eb7 | ||
|
|
b264c6540a | ||
|
|
90cdbd5504 | ||
|
|
147242cbba | ||
|
|
c09ac13f90 | ||
|
|
ec85068c67 | ||
|
|
8cbd6be687 | ||
|
|
aef9a3dc0f | ||
|
|
2294393d71 | ||
|
|
2b0d2e4751 | ||
|
|
0f8a94aa50 | ||
|
|
4eb2fab33d | ||
|
|
a43edcde7d | ||
|
|
742e601baf | ||
|
|
613f4a473d | ||
|
|
710bb023cd | ||
|
|
a7df6c0941 | ||
|
|
2d12085eb1 | ||
|
|
9a2cdc2bc4 | ||
|
|
66818266ff | ||
|
|
3affd55a90 | ||
|
|
a7322fe7ae | ||
|
|
5e3d8e5f22 | ||
|
|
128e090165 | ||
|
|
13f2cd9641 | ||
|
|
334aa214ba | ||
|
|
27c4b74e90 | ||
|
|
44c9be7958 | ||
|
|
23c9229fdd | ||
|
|
f22755df4f | ||
|
|
ee9ae96414 | ||
|
|
d5a340f6b7 | ||
|
|
0e88962e4f | ||
|
|
7e2d266a9a | ||
|
|
7bf65360f9 | ||
|
|
1c486a037b | ||
|
|
ea21d0a7b7 | ||
|
|
51830d5ce1 | ||
|
|
f0a12463a6 | ||
|
|
a8965dd271 | ||
|
|
c2fee1b7fa | ||
|
|
acc1e2f757 | ||
|
|
51f877ca1f | ||
|
|
8167633824 | ||
|
|
922acfd706 | ||
|
|
b136cc5653 | ||
|
|
52d1ac215d | ||
|
|
838d0ca27b | ||
|
|
f4ea58bdd0 | ||
|
|
6c656766f8 | ||
|
|
06e3cb4e71 | ||
|
|
1506b98fe1 | ||
|
|
2a8155cc68 | ||
|
|
35b7f44c7e | ||
|
|
4b70705252 | ||
|
|
0eda27a3bc | ||
|
|
c48f370924 | ||
|
|
dcfbd7a2e5 |
23
.github/ISSUE_TEMPLATE/bug.yml
vendored
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
name: Bug
|
||||||
|
description: Report a problem
|
||||||
|
labels: [bug]
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
Remember: Omarchy is an open source gift, not a product you bought from a vendor
|
||||||
|
|
||||||
|
- type: input
|
||||||
|
id: system-details
|
||||||
|
attributes:
|
||||||
|
label: System details
|
||||||
|
placeholder: e.g. AMD 9950X, NVIDIA 5090, Omarchy 2.1.0
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: steps
|
||||||
|
attributes:
|
||||||
|
label: What's wrong?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
1
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
blank_issues_enabled: false
|
||||||
15
.github/ISSUE_TEMPLATE/documentation.yml
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
name: Documentation
|
||||||
|
description: New pages or changes to existing
|
||||||
|
labels: [documentation]
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
Remember: Omarchy is an open source gift, not a product you bought from a vendor
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: steps
|
||||||
|
attributes:
|
||||||
|
label: What correction or addition do we need?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
15
.github/ISSUE_TEMPLATE/enhancement.yml
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
name: Enhancement
|
||||||
|
description: Feature or change
|
||||||
|
labels: [enhancement]
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
Remember: Omarchy is an open source gift, not a product you bought from a vendor
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: steps
|
||||||
|
attributes:
|
||||||
|
label: What do you need?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
BIN
applications/icons/Basecamp.png
Normal file
|
After Width: | Height: | Size: 64 KiB |
BIN
applications/icons/ChatGPT.png
Normal file
|
After Width: | Height: | Size: 34 KiB |
BIN
applications/icons/Discord.png
Normal file
|
After Width: | Height: | Size: 22 KiB |
BIN
applications/icons/Disk Usage.png
Normal file
|
After Width: | Height: | Size: 21 KiB |
BIN
applications/icons/Docker.png
Normal file
|
After Width: | Height: | Size: 13 KiB |
BIN
applications/icons/Figma.png
Normal file
|
After Width: | Height: | Size: 7.7 KiB |
BIN
applications/icons/GitHub.png
Normal file
|
After Width: | Height: | Size: 17 KiB |
BIN
applications/icons/Google Contacts.png
Normal file
|
After Width: | Height: | Size: 20 KiB |
BIN
applications/icons/Google Messages.png
Normal file
|
After Width: | Height: | Size: 17 KiB |
BIN
applications/icons/Google Photos.png
Normal file
|
After Width: | Height: | Size: 14 KiB |
BIN
applications/icons/HEY.png
Normal file
|
After Width: | Height: | Size: 196 KiB |
BIN
applications/icons/WhatsApp.png
Normal file
|
After Width: | Height: | Size: 33 KiB |
BIN
applications/icons/X.png
Normal file
|
After Width: | Height: | Size: 26 KiB |
BIN
applications/icons/YouTube.png
Normal file
|
After Width: | Height: | Size: 12 KiB |
BIN
applications/icons/Zoom.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
@@ -2,7 +2,7 @@
|
|||||||
Name=Neovim
|
Name=Neovim
|
||||||
GenericName=Text Editor
|
GenericName=Text Editor
|
||||||
Comment=Edit text files
|
Comment=Edit text files
|
||||||
Exec=alacritty --class=nvim --title=nvim -e nvim -- %F
|
Exec=$TERMINAL --class=nvim --title=nvim -e nvim -- %F
|
||||||
Terminal=false
|
Terminal=false
|
||||||
Type=Application
|
Type=Application
|
||||||
Keywords=Text;editor;
|
Keywords=Text;editor;
|
||||||
|
|||||||
@@ -6,7 +6,13 @@ BATTERY_THRESHOLD=10
|
|||||||
NOTIFICATION_FLAG="/run/user/$UID/omarchy_battery_notified"
|
NOTIFICATION_FLAG="/run/user/$UID/omarchy_battery_notified"
|
||||||
|
|
||||||
get_battery_percentage() {
|
get_battery_percentage() {
|
||||||
upower -i $(upower -e | grep 'BAT') | grep -E "percentage" | grep -o '[0-9]\+%' | sed 's/%//'
|
upower -i "$(upower -e | grep 'BAT')" \
|
||||||
|
| awk -F: '/percentage/ {
|
||||||
|
gsub(/[%[:space:]]/, "", $2);
|
||||||
|
val=$2;
|
||||||
|
printf("%d\n", (val+0.5))
|
||||||
|
exit
|
||||||
|
}'
|
||||||
}
|
}
|
||||||
|
|
||||||
get_battery_state() {
|
get_battery_state() {
|
||||||
|
|||||||
@@ -1,19 +1,50 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Find all the audio sinks but exit if there are none
|
focused_monitor="$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')"
|
||||||
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
|
sinks=$(pactl -f json list sinks | jq '[.[] | select((.ports | length == 0) or ([.ports[]? | .availability != "not available"] | any))]')
|
||||||
current=$(wpctl status | sed -n '/Sinks:/,/Sources:/p' | grep '^\s*│\s*\*' | sed -E 's/^[^0-9]*([0-9]+)\..*/\1/')
|
sinks_count=$(echo "$sinks" | jq '. | length')
|
||||||
|
|
||||||
# Find the next sink (looping around in the list)
|
if [ "$sinks_count" -eq 0 ]; then
|
||||||
for i in "${!sinks[@]}"; do
|
swayosd-client \
|
||||||
[ "${sinks[$i]}" = "$current" ] && next=${sinks[$(((i + 1) % ${#sinks[@]}))]}
|
--monitor "$focused_monitor" \
|
||||||
done
|
--custom-message "No audio devices found"
|
||||||
next=${next:-${sinks[0]}}
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# Set the next sink and ensure it's not muted
|
current_sink_name=$(pactl get-default-sink)
|
||||||
wpctl set-default "$next"
|
current_sink_index=$(echo "$sinks" | jq -r --arg name "$current_sink_name" 'map(.name) | index($name)')
|
||||||
wpctl set-mute "$next" 0
|
|
||||||
|
|
||||||
|
if [ "$current_sink_index" != "null" ]; then
|
||||||
|
next_sink_index=$(((current_sink_index + 1) % sinks_count))
|
||||||
|
else
|
||||||
|
next_sink_index=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
next_sink=$(echo "$sinks" | jq -r ".[$next_sink_index]")
|
||||||
|
next_sink_name=$(echo "$next_sink" | jq -r '.name')
|
||||||
|
next_sink_description=$(echo "$next_sink" | jq -r '.description')
|
||||||
|
next_sink_volume=$(echo "$next_sink" | jq -r \
|
||||||
|
'.volume | to_entries[0].value.value_percent | sub("%"; "")')
|
||||||
|
next_sink_is_muted=$(echo "$next_sink" | jq -r '.mute')
|
||||||
|
|
||||||
|
if [ "$next_sink_is_muted" = "true" ] || [ "$next_sink_volume" -eq 0 ]; then
|
||||||
|
icon_state="muted"
|
||||||
|
elif [ "$next_sink_volume" -le 33 ]; then
|
||||||
|
icon_state="low"
|
||||||
|
elif [ "$next_sink_volume" -le 66 ]; then
|
||||||
|
icon_state="medium"
|
||||||
|
else
|
||||||
|
icon_state="high"
|
||||||
|
fi
|
||||||
|
|
||||||
|
next_sink_volume_icon="sink-volume-${icon_state}-symbolic"
|
||||||
|
|
||||||
|
if [ "$next_sink_name" != "$current_sink_name" ]; then
|
||||||
|
pactl set-default-sink "$next_sink_name"
|
||||||
|
fi
|
||||||
|
|
||||||
|
swayosd-client \
|
||||||
|
--monitor "$focused_monitor" \
|
||||||
|
--custom-message "$next_sink_description" \
|
||||||
|
--custom-icon "$next_sink_volume_icon"
|
||||||
|
|||||||
@@ -6,7 +6,12 @@ FIRST_RUN_MODE=~/.local/state/omarchy/first-run.mode
|
|||||||
|
|
||||||
if [[ -f "$FIRST_RUN_MODE" ]]; then
|
if [[ -f "$FIRST_RUN_MODE" ]]; then
|
||||||
rm -f "$FIRST_RUN_MODE"
|
rm -f "$FIRST_RUN_MODE"
|
||||||
$OMARCHY_PATH/install/first-run/battery-monitor.sh
|
|
||||||
$OMARCHY_PATH/install/first-run/firewall.sh
|
bash "$OMARCHY_PATH/install/first-run/battery-monitor.sh"
|
||||||
|
bash "$OMARCHY_PATH/install/first-run/firewall.sh"
|
||||||
|
bash "$OMARCHY_PATH/install/first-run/gnome-theme.sh"
|
||||||
sudo rm -f /etc/sudoers.d/first-run
|
sudo rm -f /etc/sudoers.d/first-run
|
||||||
|
|
||||||
|
bash "$OMARCHY_PATH/install/first-run/wifi.sh"
|
||||||
|
bash "$OMARCHY_PATH/install/first-run/welcome.sh"
|
||||||
fi
|
fi
|
||||||
|
|||||||
9
bin/omarchy-cmd-missing
Executable file
@@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for cmd in "$@"; do
|
||||||
|
if ! command -v "$cmd" &>/dev/null; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 1
|
||||||
7
bin/omarchy-cmd-present
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for cmd in "$@"; do
|
||||||
|
command -v "$cmd" &>/dev/null || exit 1
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 0
|
||||||
@@ -8,25 +8,47 @@ if [[ ! -d "$OUTPUT_DIR" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
screenrecording() {
|
# Selects region or output
|
||||||
filename="$OUTPUT_DIR/screenrecording-$(date +'%Y-%m-%d_%H-%M-%S').mp4"
|
SCOPE="$1"
|
||||||
notify-send "Screen recording starting..." -t 1000
|
|
||||||
sleep 1
|
|
||||||
|
|
||||||
if lspci | grep -Eqi 'nvidia|intel.*graphics'; then
|
# Selects audio inclusion or not
|
||||||
wf-recorder -f "$filename" -c libx264 -p crf=23 -p preset=medium -p movflags=+faststart "$@"
|
AUDIO=$([[ $2 == "audio" ]] && echo "--audio")
|
||||||
|
|
||||||
|
start_screenrecording() {
|
||||||
|
filename="$OUTPUT_DIR/screenrecording-$(date +'%Y-%m-%d_%H-%M-%S').mp4"
|
||||||
|
|
||||||
|
if lspci | grep -qi 'nvidia'; then
|
||||||
|
wf-recorder $AUDIO -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 $AUDIO -f "$filename" --ffmpeg-encoder-options="-c:v libx264 -crf 23 -preset medium -movflags +faststart" "$@" &
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
toggle_screenrecording_indicator
|
||||||
}
|
}
|
||||||
|
|
||||||
if pgrep -x wl-screenrec >/dev/null || pgrep -x wf-recorder >/dev/null; then
|
stop_screenrecording() {
|
||||||
pkill -x wl-screenrec
|
pkill -x wl-screenrec
|
||||||
pkill -x wf-recorder
|
pkill -x wf-recorder
|
||||||
|
|
||||||
notify-send "Screen recording saved to $OUTPUT_DIR" -t 2000
|
notify-send "Screen recording saved to $OUTPUT_DIR" -t 2000
|
||||||
elif [[ "$1" == "output" ]]; then
|
|
||||||
screenrecording
|
sleep 0.2 # ensures the process is actually dead before we check
|
||||||
|
toggle_screenrecording_indicator
|
||||||
|
}
|
||||||
|
|
||||||
|
toggle_screenrecording_indicator() {
|
||||||
|
pkill -RTMIN+8 waybar
|
||||||
|
}
|
||||||
|
|
||||||
|
screenrecording_active() {
|
||||||
|
pgrep -x wl-screenrec >/dev/null || pgrep -x wf-recorder >/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
if screenrecording_active; then
|
||||||
|
stop_screenrecording
|
||||||
|
elif [[ "$SCOPE" == "output" ]]; then
|
||||||
|
start_screenrecording
|
||||||
else
|
else
|
||||||
region=$(slurp) || exit 1
|
region=$(slurp) || exit 1
|
||||||
screenrecording -g "$region"
|
start_screenrecording -g "$region"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -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
|
|
||||||
@@ -1,5 +1,20 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
screensaver_in_focus() {
|
||||||
|
hyprctl activewindow -j | jq -e '.class == "Screensaver"' >/dev/null 2>&1
|
||||||
|
}
|
||||||
|
|
||||||
|
exit_screensaver() {
|
||||||
|
hyprctl keyword cursor:invisible false
|
||||||
|
pkill -x tte 2>/dev/null
|
||||||
|
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
trap exit_screensaver SIGINT SIGTERM SIGHUP SIGQUIT
|
||||||
|
|
||||||
|
hyprctl keyword cursor:invisible true
|
||||||
|
|
||||||
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 ~/.config/omarchy/branding/screensaver.txt \
|
||||||
@@ -7,10 +22,8 @@ while true; do
|
|||||||
"$effect" &
|
"$effect" &
|
||||||
|
|
||||||
while pgrep -x tte >/dev/null; do
|
while pgrep -x tte >/dev/null; do
|
||||||
if read -n 1 -t 0.01; then
|
if read -n 1 -t 3 || ! screensaver_in_focus; then
|
||||||
pkill -x tte 2>/dev/null
|
exit_screensaver
|
||||||
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
|
||||||
exit 0
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
|
|||||||
44
bin/omarchy-cmd-share
Executable file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-cmd-share [clipboard|file|folder]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
MODE="$1"
|
||||||
|
shift
|
||||||
|
|
||||||
|
if [[ $MODE == "clipboard" ]]; then
|
||||||
|
TEMP_FILE=$(mktemp --suffix=.txt)
|
||||||
|
wl-paste >"$TEMP_FILE"
|
||||||
|
FILES="$TEMP_FILE"
|
||||||
|
else
|
||||||
|
if (($# > 0)); then
|
||||||
|
FILES="$*"
|
||||||
|
else
|
||||||
|
if [[ $MODE == "folder" ]]; then
|
||||||
|
# Pick a single folder from home directory
|
||||||
|
FILES=$(find "$HOME" -type d 2>/dev/null | fzf)
|
||||||
|
else
|
||||||
|
# Pick one or more files from home directory
|
||||||
|
FILES=$(find "$HOME" -type f 2>/dev/null | fzf --multi)
|
||||||
|
fi
|
||||||
|
[ -z "$FILES" ] && exit 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Run LocalSend in its own systemd service (detached from terminal)
|
||||||
|
# Convert newline-separated files to space-separated arguments
|
||||||
|
if [[ $MODE != "clipboard" ]] && echo "$FILES" | grep -q $'\n'; then
|
||||||
|
# Multiple files selected - convert newlines to array
|
||||||
|
readarray -t FILE_ARRAY <<<"$FILES"
|
||||||
|
systemd-run --user --quiet --collect localsend --headless send "${FILE_ARRAY[@]}"
|
||||||
|
else
|
||||||
|
# Single file or clipboard mode
|
||||||
|
systemd-run --user --quiet --collect localsend --headless send "$FILES"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Note: Temporary file will remain until system cleanup for clipboard mode
|
||||||
|
# This ensures the file content is available for the LocalSend GUI
|
||||||
|
|
||||||
|
exit 0
|
||||||
@@ -5,7 +5,7 @@ terminal_pid=$(hyprctl activewindow | awk '/pid:/ {print $2}')
|
|||||||
shell_pid=$(pgrep -P "$terminal_pid" | head -n1)
|
shell_pid=$(pgrep -P "$terminal_pid" | head -n1)
|
||||||
|
|
||||||
if [[ -n $shell_pid ]]; then
|
if [[ -n $shell_pid ]]; then
|
||||||
readlink -f "/proc/$shell_pid/cwd" 2>/dev/null
|
readlink -f "/proc/$shell_pid/cwd" 2>/dev/null || echo "$HOME"
|
||||||
else
|
else
|
||||||
echo "$HOME"
|
echo "$HOME"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
notify-send " Updating time and timezone..."
|
||||||
sudo systemctl restart systemd-timesyncd
|
sudo systemctl restart systemd-timesyncd
|
||||||
sudo tzupdate
|
sudo tzupdate
|
||||||
new_timezone=$(timedatectl show -p Timezone --value)
|
new_timezone=$(timedatectl show -p Timezone --value)
|
||||||
omarchy-restart-waybar
|
omarchy-restart-waybar
|
||||||
notify-send "Time synced and timezone set to $new_timezone"
|
notify-send " Time updated and timezone set to $new_timezone"
|
||||||
|
|||||||
28
bin/omarchy-drive-info
Executable file
@@ -0,0 +1,28 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Drive, like /dev/nvme0, to display information about
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-drive-info [/dev/drive]"
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
drive="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Find the root drive in case we are looking at partitions
|
||||||
|
root_drive=$(lsblk -no PKNAME "$drive" 2>/dev/null | tail -n1)
|
||||||
|
if [[ -n "$root_drive" ]]; then
|
||||||
|
root_drive="/dev/$root_drive"
|
||||||
|
else
|
||||||
|
root_drive="$drive"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Get basic disk information
|
||||||
|
size=$(lsblk -dno SIZE "$drive" 2>/dev/null)
|
||||||
|
model=$(lsblk -dno MODEL "$root_drive" 2>/dev/null)
|
||||||
|
|
||||||
|
# Format display string
|
||||||
|
display="$drive"
|
||||||
|
[[ -n "$size" ]] && display="$display ($size)"
|
||||||
|
[[ -n "$model" ]] && display="$display - $model"
|
||||||
|
|
||||||
|
echo "$display"
|
||||||
18
bin/omarchy-drive-select
Executable file
@@ -0,0 +1,18 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Select a drive from a list with info that includes space and brand
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
drives=$(lsblk -dpno NAME | grep -E '/dev/(sd|hd|vd|nvme|mmcblk|xv)')
|
||||||
|
else
|
||||||
|
drives="$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
drives_with_info=""
|
||||||
|
while IFS= read -r drive; do
|
||||||
|
[[ -n "$drive" ]] || continue
|
||||||
|
drives_with_info+="$(omarchy-drive-info "$drive")"$'\n'
|
||||||
|
done <<<"$drives"
|
||||||
|
|
||||||
|
selected_drive="$(printf "%s" "$drives_with_info" | gum choose --header "Select drive")" || exit 1
|
||||||
|
printf "%s\n" "$selected_drive" | awk '{print $1}'
|
||||||
21
bin/omarchy-drive-set-password
Executable file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
encrypted_drives=$(blkid -t TYPE=crypto_LUKS -o device)
|
||||||
|
|
||||||
|
if [[ -n $encrypted_drives ]]; then
|
||||||
|
if [[ $(wc -l <<<"$encrypted_drives") -eq 1 ]]; then
|
||||||
|
drive_to_change="$encrypted_drives"
|
||||||
|
else
|
||||||
|
drive_to_change="$(omarchy-drive-select "$encrypted_drives")"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n $drive_to_change ]]; then
|
||||||
|
echo "Changing full-disk encryption password for $drive_to_change"
|
||||||
|
sudo cryptsetup luksChangeKey --pbkdf argon2id --iter-time 2000 "$drive_to_change"
|
||||||
|
else
|
||||||
|
echo "No drive selected."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "No encrypted drives available."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
@@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
grep -oP 'family\s*=\s*"\K[^"]+' ~/.config/alacritty/alacritty.toml | head -n1
|
grep -oP 'font-family:\s*["'\'']?\K[^;"'\'']+' ~/.config/waybar/style.css | head -n1
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
fc-list :spacing=100 -f "%{family[0]}\n" | grep -v -i -E 'emoji|signwriting' | sort -u
|
fc-list :spacing=100 -f "%{family[0]}\n" | grep -v -i -E 'emoji|signwriting|omarchy' | sort -u
|
||||||
|
|||||||
@@ -4,7 +4,20 @@ 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
|
if [[ -f ~/.config/alacritty/alacritty.toml ]]; then
|
||||||
|
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -f ~/.config/kitty/kitty.conf ]]; then
|
||||||
|
sed -i "s/^font_family .*/font_family $font_name/g" ~/.config/kitty/kitty.conf
|
||||||
|
pkill -USR1 kitty
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -f ~/.config/ghostty/config ]]; then
|
||||||
|
sed -i "s/font-family = \".*\"/font-family = \"$font_name\"/g" ~/.config/ghostty/config
|
||||||
|
pkill -SIGUSR2 ghostty
|
||||||
|
fi
|
||||||
|
|
||||||
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 \
|
||||||
|
|||||||
13
bin/omarchy-install-chromium-google-account
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [[ -f ~/.config/chromium-flags.conf ]]; then
|
||||||
|
CONF=~/.config/chromium-flags.conf
|
||||||
|
|
||||||
|
grep -qxF -- "--oauth2-client-id=77185425430.apps.googleusercontent.com" "$CONF" ||
|
||||||
|
echo "--oauth2-client-id=77185425430.apps.googleusercontent.com" >>"$CONF"
|
||||||
|
|
||||||
|
grep -qxF -- "--oauth2-client-secret=OTJgUOQcT7lO7GsGZq2G4IlT" "$CONF" ||
|
||||||
|
echo "--oauth2-client-secret=OTJgUOQcT7lO7GsGZq2G4IlT" >>"$CONF"
|
||||||
|
|
||||||
|
echo "Now you can login to your Google Account in Chromium."
|
||||||
|
fi
|
||||||
@@ -1,12 +1,12 @@
|
|||||||
#!/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-install-dev-env <ruby|node|bun|go|laravel|symfony|php|python|elixir|phoenix|rust|java|ocaml|dotnet|clojure>" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
install_php() {
|
install_php() {
|
||||||
sudo pacman -Sy php composer php-sqlite --noconfirm
|
sudo pacman -S php composer php-sqlite xdebug --noconfirm
|
||||||
|
|
||||||
# Install Path for Composer
|
# Install Path for Composer
|
||||||
if [[ ":$PATH:" != *":$HOME/.config/composer/vendor/bin:"* ]]; then
|
if [[ ":$PATH:" != *":$HOME/.config/composer/vendor/bin:"* ]]; then
|
||||||
@@ -28,11 +28,22 @@ install_php() {
|
|||||||
"pdo_mysql"
|
"pdo_mysql"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Enable Xdebug
|
||||||
|
sudo sed -i \
|
||||||
|
-e 's/^;zend_extension=xdebug.so/zend_extension=xdebug.so/' \
|
||||||
|
-e 's/^;xdebug.mode=debug/xdebug.mode=debug/' \
|
||||||
|
/etc/php/conf.d/xdebug.ini
|
||||||
|
|
||||||
for ext in "${extensions_to_enable[@]}"; do
|
for ext in "${extensions_to_enable[@]}"; do
|
||||||
sudo sed -i "s/^;extension=${ext}/extension=${ext}/" "$php_ini_path"
|
sudo sed -i "s/^;extension=${ext}/extension=${ext}/" "$php_ini_path"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
install_node() {
|
||||||
|
echo -e "Installing Node.js...\n"
|
||||||
|
mise use --global node@lts
|
||||||
|
}
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
ruby)
|
ruby)
|
||||||
echo -e "Installing Ruby on Rails...\n"
|
echo -e "Installing Ruby on Rails...\n"
|
||||||
@@ -42,8 +53,7 @@ ruby)
|
|||||||
echo -e "\nYou can now run: rails new myproject"
|
echo -e "\nYou can now run: rails new myproject"
|
||||||
;;
|
;;
|
||||||
node)
|
node)
|
||||||
echo -e "Installing Node.js...\n"
|
install_node
|
||||||
mise use --global node@lts
|
|
||||||
;;
|
;;
|
||||||
bun)
|
bun)
|
||||||
echo -e "Installing Bun...\n"
|
echo -e "Installing Bun...\n"
|
||||||
@@ -64,13 +74,14 @@ php)
|
|||||||
laravel)
|
laravel)
|
||||||
echo -e "Installing PHP and Laravel...\n"
|
echo -e "Installing PHP and Laravel...\n"
|
||||||
install_php
|
install_php
|
||||||
|
install_node
|
||||||
composer global require laravel/installer
|
composer global require laravel/installer
|
||||||
echo -e "\nYou can now run: laravel new myproject"
|
echo -e "\nYou can now run: laravel new myproject"
|
||||||
;;
|
;;
|
||||||
symfony)
|
symfony)
|
||||||
echo -e "Installing PHP and Symfony...\n"
|
echo -e "Installing PHP and Symfony...\n"
|
||||||
install_php
|
install_php
|
||||||
yay -S symfony-cli --noconfirm
|
omarchy-pkg-add symfony-cli
|
||||||
echo -e "\nYou can now run: symfony new --webapp myproject"
|
echo -e "\nYou can now run: symfony new --webapp myproject"
|
||||||
;;
|
;;
|
||||||
python)
|
python)
|
||||||
@@ -108,6 +119,7 @@ java)
|
|||||||
zig)
|
zig)
|
||||||
echo -e "Installing Zig...\n"
|
echo -e "Installing Zig...\n"
|
||||||
mise use --global zig@latest
|
mise use --global zig@latest
|
||||||
|
mise use -g zls@latest
|
||||||
;;
|
;;
|
||||||
ocaml)
|
ocaml)
|
||||||
echo -e "Installing OCaml...\n"
|
echo -e "Installing OCaml...\n"
|
||||||
@@ -120,4 +132,9 @@ dotnet)
|
|||||||
echo -e "Installing .NET...\n"
|
echo -e "Installing .NET...\n"
|
||||||
mise use --global dotnet@latest
|
mise use --global dotnet@latest
|
||||||
;;
|
;;
|
||||||
|
clojure)
|
||||||
|
echo -e "Installing Clojure...\n"
|
||||||
|
omarchy-pkg-add rlwrap
|
||||||
|
mise use --global clojure@latest
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@@ -1,16 +1,23 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
options=("MySQL" "PostgreSQL" "Redis" "MongoDB" "MariaDB")
|
options=("MySQL" "PostgreSQL" "Redis" "MongoDB" "MariaDB")
|
||||||
choices=$(printf "%s\n" "${options[@]}" | gum choose --no-limit --header "Select databases (space to select, return to install, esc to cancel)") || main_menu
|
|
||||||
|
if [[ "$#" -eq 0 ]]; then
|
||||||
|
choices=$(printf "%s\n" "${options[@]}" | gum choose --header "Select databases (space to select, return to install, esc to cancel)") || main_menu
|
||||||
|
else
|
||||||
|
choices="$@"
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ -n "$choices" ]]; then
|
if [[ -n "$choices" ]]; then
|
||||||
for db in $choices; do
|
for db in $choices; do
|
||||||
case $db in
|
case $db in
|
||||||
MySQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mysql8 -e MYSQL_ROOT_PASSWORD= -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:8.4 ;;
|
MySQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mysql8 -e MYSQL_ROOT_PASSWORD= -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:8.4 ;;
|
||||||
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=postgres17 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:17 ;;
|
||||||
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 ;;
|
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
|
||||||
|
else
|
||||||
|
echo "No databases selected for installation."
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo "Installing all dependencies..."
|
echo "Installing all dependencies..."
|
||||||
sudo pacman -S --noconfirm --needed \
|
omarchy-pkg-add dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
||||||
dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
|
||||||
|
|
||||||
echo "Starting Dropbox..."
|
echo "Starting Dropbox..."
|
||||||
uwsm app -- dropbox-cli start &>/dev/null &
|
uwsm app -- dropbox-cli start &>/dev/null &
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo "Adding multilib repository for 32-bit compatibility"
|
|
||||||
sudo sed -i '/^\s*#\[multilib\]/,/^$/{s/^\s*#//}' /etc/pacman.conf
|
|
||||||
sudo pacman -Sy
|
|
||||||
|
|
||||||
echo "Now pick dependencies matching your graphics card"
|
echo "Now pick dependencies matching your graphics card"
|
||||||
sudo pacman -S steam
|
sudo pacman -Syu --noconfirm steam
|
||||||
setsid gtk-launch steam >/dev/null 2>&1 &
|
setsid gtk-launch steam >/dev/null 2>&1 &
|
||||||
|
|||||||
19
bin/omarchy-install-terminal
Executable file
@@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-install-terminal [alacritty|ghostty|kitty]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
package="$1"
|
||||||
|
|
||||||
|
# Install package
|
||||||
|
omarchy-pkg-add $package
|
||||||
|
|
||||||
|
# Set as default terminal
|
||||||
|
echo "Setting $package as new default terminal..."
|
||||||
|
sed -i "/export TERMINAL=/ c\export TERMINAL=$package" ~/.config/uwsm/default
|
||||||
|
|
||||||
|
# Relaunch is needed for new default to take effect
|
||||||
|
echo
|
||||||
|
gum confirm "Relaunch Hyprland to use new terminal?" && uwsm stop
|
||||||
3
bin/omarchy-launch-about
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
exec setsid uwsm app -- alacritty --class=Omarchy -o font.size=9 -e bash -c 'fastfetch; read -n 1 -s'
|
||||||
@@ -1,3 +1,12 @@
|
|||||||
#!/bin/bash
|
#!/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[@]} $@
|
default_browser=$(xdg-settings get default-web-browser)
|
||||||
|
browser_exec=$(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,~/.nix-profile,/usr}/share/applications/$default_browser 2>/dev/null | head -1)
|
||||||
|
|
||||||
|
if [[ $browser_exec =~ (firefox|zen|librewolf) ]]; then
|
||||||
|
private_flag="--private-window"
|
||||||
|
else
|
||||||
|
private_flag="--incognito"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec setsid uwsm app -- "$browser_exec" "${@/--private/$private_flag}"
|
||||||
|
|||||||
10
bin/omarchy-launch-editor
Executable file
@@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
case "${EDITOR:-nvim}" in
|
||||||
|
nvim | vim | nano | micro | hx)
|
||||||
|
exec setsid uwsm app -- "$TERMINAL" -e "$EDITOR" "$@"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
exec setsid uwsm app -- "$EDITOR" "$@"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
4
bin/omarchy-launch-floating-terminal-with-presentation
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
cmd="$*"
|
||||||
|
exec setsid uwsm app -- alacritty --class=Omarchy --title=Omarchy -e bash -c "omarchy-show-logo; $cmd; omarchy-show-done"
|
||||||
16
bin/omarchy-launch-or-focus
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-launch-or-focus [window-pattern] [launch-command]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
WINDOW_PATTERN="$1"
|
||||||
|
LAUNCH_COMMAND="${2:-"uwsm app -- $WINDOW_PATTERN"}"
|
||||||
|
WINDOW_ADDRESS=$(hyprctl clients -j | jq -r --arg p "$WINDOW_PATTERN" '.[]|select((.class+" "+.title)|test($p;"i"))|.address' | head -n1)
|
||||||
|
|
||||||
|
if [[ -n $WINDOW_ADDRESS ]]; then
|
||||||
|
hyprctl dispatch focuswindow "address:$WINDOW_ADDRESS"
|
||||||
|
else
|
||||||
|
eval exec $LAUNCH_COMMAND
|
||||||
|
fi
|
||||||
8
bin/omarchy-launch-or-focus-webapp
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-launch-or-focus-webapp [window-pattern] [url]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec omarchy-launch-or-focus "$1" "omarchy-launch-webapp '$2'"
|
||||||
@@ -17,6 +17,8 @@ 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
|
||||||
hyprctl dispatch focusmonitor $m
|
hyprctl dispatch focusmonitor $m
|
||||||
|
|
||||||
|
# FIXME: Find a way to make this generic where we it can work for kitty + ghostty
|
||||||
hyprctl dispatch exec -- \
|
hyprctl dispatch exec -- \
|
||||||
alacritty --class Screensaver \
|
alacritty --class Screensaver \
|
||||||
--config-file ~/.local/share/omarchy/default/alacritty/screensaver.toml \
|
--config-file ~/.local/share/omarchy/default/alacritty/screensaver.toml \
|
||||||
|
|||||||
@@ -7,4 +7,4 @@ google-chrome* | brave-browser* | microsoft-edge* | opera* | vivaldi*) ;;
|
|||||||
*) browser="chromium.desktop" ;;
|
*) browser="chromium.desktop" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
exec setsid uwsm app -- $(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,/usr}/share/applications/$browser 2>/dev/null | head -1) --app="$1" "${@:2}"
|
exec setsid uwsm app -- $(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,~/.nix-profile,/usr}/share/applications/$browser 2>/dev/null | head -1) --app="$1" "${@:2}"
|
||||||
|
|||||||
3
bin/omarchy-launch-wifi
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
exec setsid uwsm app -- "$TERMINAL" --class=Impala -e impala "$@"
|
||||||
@@ -9,4 +9,4 @@ if pgrep -x "1password" >/dev/null; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Avoid running screensaver when locked
|
# Avoid running screensaver when locked
|
||||||
pkill -f "alacritty --class Screensaver"
|
pkill -f "$TERMINAL --class Screensaver"
|
||||||
|
|||||||
245
bin/omarchy-menu
@@ -2,6 +2,21 @@
|
|||||||
|
|
||||||
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
||||||
|
|
||||||
|
# Set to true when going directly to a submenu, so we can exit directly
|
||||||
|
BACK_TO_EXIT=false
|
||||||
|
|
||||||
|
back_to() {
|
||||||
|
local parent_menu="$1"
|
||||||
|
|
||||||
|
if [[ "$BACK_TO_EXIT" == "true" ]]; then
|
||||||
|
exit 0
|
||||||
|
elif [[ -n "$parent_menu" ]]; then
|
||||||
|
"$parent_menu"
|
||||||
|
else
|
||||||
|
show_main_menu
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
menu() {
|
menu() {
|
||||||
local prompt="$1"
|
local prompt="$1"
|
||||||
local options="$2"
|
local options="$2"
|
||||||
@@ -22,36 +37,40 @@ menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
terminal() {
|
terminal() {
|
||||||
alacritty --class Omarchy -e "$@"
|
alacritty --class=Omarchy -e "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
present_terminal() {
|
present_terminal() {
|
||||||
alacritty --class Omarchy -e bash -c "omarchy-show-logo; eval \"$1\"; omarchy-show-done;"
|
omarchy-launch-floating-terminal-with-presentation $1
|
||||||
}
|
}
|
||||||
|
|
||||||
edit_in_nvim() {
|
open_in_editor() {
|
||||||
notify-send "Editing config file" "$1"
|
notify-send "Editing config file" "$1"
|
||||||
alacritty -e nvim "$1"
|
omarchy-launch-editor "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
install() {
|
install() {
|
||||||
present_terminal "echo 'Installing $1...'; sudo pacman -Sy --noconfirm $2"
|
present_terminal "echo 'Installing $1...'; sudo pacman -S --noconfirm $2"
|
||||||
}
|
}
|
||||||
|
|
||||||
install_and_launch() {
|
install_and_launch() {
|
||||||
present_terminal "echo 'Installing $1...'; sudo pacman -Sy --noconfirm $2 && setsid gtk-launch $3"
|
present_terminal "echo 'Installing $1...'; sudo pacman -S --noconfirm $2 && setsid gtk-launch $3"
|
||||||
}
|
}
|
||||||
|
|
||||||
install_font() {
|
install_font() {
|
||||||
present_terminal "echo 'Installing $1...'; sudo pacman -Sy --noconfirm --needed $2 && sleep 2 && omarchy-font-set '$3'"
|
present_terminal "echo 'Installing $1...'; sudo pacman -S --noconfirm --needed $2 && sleep 2 && omarchy-font-set '$3'"
|
||||||
|
}
|
||||||
|
|
||||||
|
install_terminal() {
|
||||||
|
present_terminal "omarchy-install-terminal $1"
|
||||||
}
|
}
|
||||||
|
|
||||||
aur_install() {
|
aur_install() {
|
||||||
present_terminal "echo 'Installing $1 from AUR...'; yay -Sy --noconfirm $2"
|
present_terminal "echo 'Installing $1 from AUR...'; yay -S --noconfirm $2"
|
||||||
}
|
}
|
||||||
|
|
||||||
aur_install_and_launch() {
|
aur_install_and_launch() {
|
||||||
present_terminal "echo 'Installing $1 from AUR...'; yay -Sy --noconfirm $2 && setsid gtk-launch $3"
|
present_terminal "echo 'Installing $1 from AUR...'; yay -S --noconfirm $2 && setsid gtk-launch $3"
|
||||||
}
|
}
|
||||||
|
|
||||||
show_learn_menu() {
|
show_learn_menu() {
|
||||||
@@ -66,41 +85,21 @@ show_learn_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_style_menu() {
|
show_trigger_menu() {
|
||||||
case $(menu "Style" " Theme\n Font\n Background\n Screensaver\n About") in
|
case $(menu "Trigger" " Capture\n Share\n Toggle") in
|
||||||
*Theme*) show_theme_menu ;;
|
*Capture*) show_capture_menu ;;
|
||||||
*Font*) show_font_menu ;;
|
*Share*) show_share_menu ;;
|
||||||
*Background*) omarchy-theme-bg-next ;;
|
*Toggle*) show_toggle_menu ;;
|
||||||
*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
|
||||||
}
|
}
|
||||||
|
|
||||||
show_theme_menu() {
|
|
||||||
theme=$(menu "Theme" "$(omarchy-theme-list)" "" "$(omarchy-theme-current)")
|
|
||||||
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
|
||||||
show_main_menu
|
|
||||||
else
|
|
||||||
omarchy-theme-set "$theme"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
show_font_menu() {
|
|
||||||
theme=$(menu "Font" "$(omarchy-font-list)" "-w 350" "$(omarchy-font-current)")
|
|
||||||
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
|
||||||
show_main_menu
|
|
||||||
else
|
|
||||||
omarchy-font-set "$theme"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
show_capture_menu() {
|
show_capture_menu() {
|
||||||
case $(menu "Capture" " Screenshot\n Screenrecord\n Color") in
|
case $(menu "Capture" " Screenshot\n Screenrecord\n Color") in
|
||||||
*Screenshot*) show_screenshot_menu ;;
|
*Screenshot*) show_screenshot_menu ;;
|
||||||
*Screenrecord*) show_screenrecord_menu ;;
|
*Screenrecord*) show_screenrecord_menu ;;
|
||||||
*Color*) pkill hyprpicker || hyprpicker -a ;;
|
*Color*) pkill hyprpicker || hyprpicker -a ;;
|
||||||
*) show_main_menu ;;
|
*) show_trigger_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -114,47 +113,88 @@ show_screenshot_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_screenrecord_menu() {
|
show_screenrecord_menu() {
|
||||||
case $(menu "Screenrecord" " Region\n Display") in
|
case $(menu "Screenrecord" " Region\n Region + Audio\n Display\n Display + Audio") in
|
||||||
|
*"Region + Audio"*) omarchy-cmd-screenrecord region audio ;;
|
||||||
*Region*) omarchy-cmd-screenrecord ;;
|
*Region*) omarchy-cmd-screenrecord ;;
|
||||||
|
*"Display + Audio"*) omarchy-cmd-screenrecord output audio ;;
|
||||||
*Display*) omarchy-cmd-screenrecord output ;;
|
*Display*) omarchy-cmd-screenrecord output ;;
|
||||||
*) show_capture_menu ;;
|
*) show_capture_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_share_menu() {
|
||||||
|
case $(menu "Share" " Clipboard\n File \n Folder") in
|
||||||
|
*Clipboard*) terminal bash -c "omarchy-cmd-share clipboard" ;;
|
||||||
|
*File*) terminal bash -c "omarchy-cmd-share file" ;;
|
||||||
|
*Folder*) terminal bash -c "omarchy-cmd-share folder" ;;
|
||||||
|
*) back_to show_trigger_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
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-toggle-screensaver ;;
|
||||||
*Nightlight*) omarchy-toggle-nightlight ;;
|
*Nightlight*) omarchy-toggle-nightlight ;;
|
||||||
*Idle*) omarchy-toggle-idle ;;
|
*Idle*) omarchy-toggle-idle ;;
|
||||||
*Bar*) omarchy-toggle-waybar ;;
|
*Bar*) omarchy-toggle-waybar ;;
|
||||||
|
*) show_trigger_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_style_menu() {
|
||||||
|
case $(menu "Style" " Theme\n Font\n Background\n Hyprland\n Screensaver\n About") in
|
||||||
|
*Theme*) show_theme_menu ;;
|
||||||
|
*Font*) show_font_menu ;;
|
||||||
|
*Background*) omarchy-theme-bg-next ;;
|
||||||
|
*Hyprland*) open_in_editor ~/.config/hypr/looknfeel.conf ;;
|
||||||
|
*Screensaver*) open_in_editor ~/.config/omarchy/branding/screensaver.txt ;;
|
||||||
|
*About*) open_in_editor ~/.config/omarchy/branding/about.txt ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_theme_menu() {
|
||||||
|
theme=$(menu "Theme" "$(omarchy-theme-list)" "" "$(omarchy-theme-current)")
|
||||||
|
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
||||||
|
back_to show_style_menu
|
||||||
|
else
|
||||||
|
omarchy-theme-set "$theme"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
show_font_menu() {
|
||||||
|
theme=$(menu "Font" "$(omarchy-font-list)" "-w 350" "$(omarchy-font-current)")
|
||||||
|
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
||||||
|
back_to show_style_menu
|
||||||
|
else
|
||||||
|
omarchy-font-set "$theme"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
show_setup_menu() {
|
show_setup_menu() {
|
||||||
local options=" Audio\n Wifi\n Bluetooth\n Power Profile\n Monitors"
|
local options=" Audio\n Wifi\n Bluetooth\n Power Profile\n Monitors"
|
||||||
[ -f ~/.config/hypr/bindings.conf ] && options="$options\n Keybindings"
|
[ -f ~/.config/hypr/bindings.conf ] && options="$options\n Keybindings"
|
||||||
[ -f ~/.config/hypr/input.conf ] && options="$options\n Input"
|
[ -f ~/.config/hypr/input.conf ] && options="$options\n Input"
|
||||||
options="$options\n DNS\n Config\n Fingerprint\n Fido2"
|
options="$options\n Defaults\n DNS\n Security\n Config"
|
||||||
|
|
||||||
case $(menu "Setup" "$options") in
|
case $(menu "Setup" "$options") in
|
||||||
*Audio*) alacritty --class=Wiremix -e wiremix ;;
|
*Audio*) $TERMINAL --class=Wiremix -e wiremix ;;
|
||||||
*Wifi*)
|
*Wifi*)
|
||||||
rfkill unblock wifi
|
rfkill unblock wifi
|
||||||
alacritty --class=Impala -e impala
|
omarchy-launch-wifi
|
||||||
;;
|
;;
|
||||||
*Bluetooth*)
|
*Bluetooth*)
|
||||||
rfkill unblock bluetooth
|
rfkill unblock bluetooth
|
||||||
blueberry
|
blueberry
|
||||||
;;
|
;;
|
||||||
*Power*) show_setup_power_menu ;;
|
*Power*) show_setup_power_menu ;;
|
||||||
*Monitors*) edit_in_nvim ~/.config/hypr/monitors.conf ;;
|
*Monitors*) open_in_editor ~/.config/hypr/monitors.conf ;;
|
||||||
*Keybindings*) edit_in_nvim ~/.config/hypr/bindings.conf ;;
|
*Keybindings*) open_in_editor ~/.config/hypr/bindings.conf ;;
|
||||||
*Input*) edit_in_nvim ~/.config/hypr/input.conf ;;
|
*Input*) open_in_editor ~/.config/hypr/input.conf ;;
|
||||||
|
*Defaults*) open_in_editor ~/.config/uwsm/default ;;
|
||||||
*DNS*) present_terminal omarchy-setup-dns ;;
|
*DNS*) present_terminal omarchy-setup-dns ;;
|
||||||
|
*Security*) show_setup_security_menu ;;
|
||||||
*Config*) show_setup_config_menu ;;
|
*Config*) show_setup_config_menu ;;
|
||||||
*Fingerprint*) present_terminal omarchy-setup-fingerprint ;;
|
|
||||||
*Fido2*) present_terminal omarchy-setup-fido2 ;;
|
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -163,7 +203,7 @@ show_setup_power_menu() {
|
|||||||
profile=$(menu "Power Profile" "$(omarchy-powerprofiles-list)" "" "$(powerprofilesctl get)")
|
profile=$(menu "Power Profile" "$(omarchy-powerprofiles-list)" "" "$(powerprofilesctl get)")
|
||||||
|
|
||||||
if [[ "$profile" == "CNCLD" || -z "$profile" ]]; then
|
if [[ "$profile" == "CNCLD" || -z "$profile" ]]; then
|
||||||
show_main_menu
|
back_to show_setup_menu
|
||||||
else
|
else
|
||||||
powerprofilesctl set "$profile"
|
powerprofilesctl set "$profile"
|
||||||
fi
|
fi
|
||||||
@@ -171,20 +211,28 @@ show_setup_power_menu() {
|
|||||||
|
|
||||||
show_setup_config_menu() {
|
show_setup_config_menu() {
|
||||||
case $(menu "Setup" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Swayosd\n Walker\n Waybar\n XCompose") in
|
case $(menu "Setup" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Swayosd\n Walker\n Waybar\n XCompose") in
|
||||||
*Hyprland*) edit_in_nvim ~/.config/hypr/hyprland.conf ;;
|
*Hyprland*) open_in_editor ~/.config/hypr/hyprland.conf ;;
|
||||||
*Hypridle*) edit_in_nvim ~/.config/hypr/hypridle.conf && omarchy-restart-hypridle ;;
|
*Hypridle*) open_in_editor ~/.config/hypr/hypridle.conf && omarchy-restart-hypridle ;;
|
||||||
*Hyprlock*) edit_in_nvim ~/.config/hypr/hyprlock.conf ;;
|
*Hyprlock*) open_in_editor ~/.config/hypr/hyprlock.conf ;;
|
||||||
*Hyprsunset*) edit_in_nvim ~/.config/hypr/hyprsunset.conf && omarchy-restart-hyprsunset ;;
|
*Hyprsunset*) open_in_editor ~/.config/hypr/hyprsunset.conf && omarchy-restart-hyprsunset ;;
|
||||||
*Swayosd*) edit_in_nvim ~/.config/swayosd/config.toml && omarchy-restart-swayosd ;;
|
*Swayosd*) open_in_editor ~/.config/swayosd/config.toml && omarchy-restart-swayosd ;;
|
||||||
*Walker*) edit_in_nvim ~/.config/walker/config.toml && omarchy-restart-walker ;;
|
*Walker*) open_in_editor ~/.config/walker/config.toml && omarchy-restart-walker ;;
|
||||||
*Waybar*) edit_in_nvim ~/.config/waybar/config.jsonc && omarchy-restart-waybar ;;
|
*Waybar*) open_in_editor ~/.config/waybar/config.jsonc && omarchy-restart-waybar ;;
|
||||||
*XCompose*) edit_in_nvim ~/.XCompose && omarchy-restart-xcompose ;;
|
*XCompose*) open_in_editor ~/.XCompose && omarchy-restart-xcompose ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_setup_security_menu() {
|
||||||
|
case $(menu "Setup" " Fingerprint\n Fido2") in
|
||||||
|
*Fingerprint*) present_terminal omarchy-setup-fingerprint ;;
|
||||||
|
*Fido2*) present_terminal omarchy-setup-fido2 ;;
|
||||||
|
*) show_setup_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
show_install_menu() {
|
show_install_menu() {
|
||||||
case $(menu "Install" " Package\n AUR\n Web App\n TUI\n Service\n Style\n Development\n Editor\n AI\n Gaming") in
|
case $(menu "Install" " Package\n AUR\n Web App\n TUI\n Service\n Style\n Development\n Editor\n Terminal\n AI\n Gaming") in
|
||||||
*Package*) terminal omarchy-pkg-install ;;
|
*Package*) terminal omarchy-pkg-install ;;
|
||||||
*AUR*) terminal omarchy-pkg-aur-install ;;
|
*AUR*) terminal omarchy-pkg-aur-install ;;
|
||||||
*Web*) present_terminal omarchy-webapp-install ;;
|
*Web*) present_terminal omarchy-webapp-install ;;
|
||||||
@@ -193,6 +241,7 @@ show_install_menu() {
|
|||||||
*Style*) show_install_style_menu ;;
|
*Style*) show_install_style_menu ;;
|
||||||
*Development*) show_install_development_menu ;;
|
*Development*) show_install_development_menu ;;
|
||||||
*Editor*) show_install_editor_menu ;;
|
*Editor*) show_install_editor_menu ;;
|
||||||
|
*Terminal*) show_install_terminal_menu ;;
|
||||||
*AI*) show_install_ai_menu ;;
|
*AI*) show_install_ai_menu ;;
|
||||||
*Gaming*) show_install_gaming_menu ;;
|
*Gaming*) show_install_gaming_menu ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
@@ -200,32 +249,51 @@ show_install_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_install_service_menu() {
|
show_install_service_menu() {
|
||||||
case $(menu "Install" " Dropbox\n Tailscale") in
|
case $(menu "Install" " Dropbox\n Tailscale\n Bitwarden\n Chromium Account") in
|
||||||
*Dropbox*) present_terminal omarchy-install-dropbox ;;
|
*Dropbox*) present_terminal omarchy-install-dropbox ;;
|
||||||
*Tailscale*) present_terminal omarchy-install-tailscale ;;
|
*Tailscale*) present_terminal omarchy-install-tailscale ;;
|
||||||
|
*Bitwarden*) install_and_launch "Bitwarden" "bitwarden bitwarden-cli" "bitwarden" ;;
|
||||||
|
*Chromium*) present_terminal omarchy-install-chromium-google-account ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_editor_menu() {
|
show_install_editor_menu() {
|
||||||
case $(menu "Install" " VSCode\n Cursor [AUR]\n Zed\n Sublime Text\n Helix") in
|
case $(menu "Install" " VSCode\n Cursor\n Zed\n Sublime Text\n Helix\n Emacs") in
|
||||||
*VSCode*) install_and_launch "VSCode" "visual-studio-code-bin" "code" ;;
|
*VSCode*) install_and_launch "VSCode" "visual-studio-code-bin" "code" ;;
|
||||||
*Cursor*) aur_install_and_launch "Cursor" "cursor-bin" "cursor" ;;
|
*Cursor*) install_and_launch "Cursor" "cursor-bin" "cursor" ;;
|
||||||
*Zed*) install_and_launch "Zed" "zed" "dev.zed.Zed" ;;
|
*Zed*) install_and_launch "Zed" "zed" "dev.zed.Zed" ;;
|
||||||
*Sublime*) install_and_launch "Sublime Text" "sublime-text-4" "sublime_text" ;;
|
*Sublime*) aur_install_and_launch "Sublime Text" "sublime-text-4" "sublime_text" ;;
|
||||||
*Helix*) install "Helix" "helix" ;;
|
*Helix*) install "Helix" "helix" ;;
|
||||||
|
*Emacs*) install "Emacs" "emacs-wayland" && systemctl --user enable --now emacs.service ;;
|
||||||
|
*) show_install_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_install_terminal_menu() {
|
||||||
|
case $(menu "Install" " Alacritty\n Ghostty\n Kitty") in
|
||||||
|
*Alacritty*) install_terminal "alacritty" ;;
|
||||||
|
*Ghostty*) install_terminal "ghostty" ;;
|
||||||
|
*Kitty*) install_terminal "kitty" ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_ai_menu() {
|
show_install_ai_menu() {
|
||||||
case $(menu "Install" " Claude Code\n Gemini\n LM Studio [AUR]\n Ollama\n Crush [AUR]\n opencode [AUR]") in
|
ollama_pkg=$(
|
||||||
|
(command -v nvidia-smi &>/dev/null && echo ollama-cuda) ||
|
||||||
|
(command -v rocminfo &>/dev/null && echo ollama-rocm) ||
|
||||||
|
echo ollama
|
||||||
|
)
|
||||||
|
|
||||||
|
case $(menu "Install" " Claude Code\n Gemini [AUR]\n OpenAI Codex [AUR]\n LM Studio\n Ollama\n Crush\n opencode") in
|
||||||
*Claude*) install "Claude Code" "claude-code" ;;
|
*Claude*) install "Claude Code" "claude-code" ;;
|
||||||
*Gemini*) install "Gemini" "gemini-cli" ;;
|
*OpenAI*) aur_install "OpenAI Codex" "openai-codex-bin" ;;
|
||||||
*Studio*) aur_install "LM Studio" "lmstudio" ;;
|
*Gemini*) aur_install "Gemini" "gemini-cli" ;;
|
||||||
*Ollama*) install "Ollama" "ollama" ;;
|
*Studio*) install "LM Studio" "lmstudio" ;;
|
||||||
*Crush*) aur_install "Crush" "crush-bin" ;;
|
*Ollama*) install "Ollama" $ollama_pkg ;;
|
||||||
*opencode*) aur_install "opencode" "opencode-bin" ;;
|
*Crush*) install "Crush" "crush-bin" ;;
|
||||||
|
*opencode*) install "opencode" "opencode" ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -234,7 +302,7 @@ show_install_gaming_menu() {
|
|||||||
case $(menu "Install" " Steam\n RetroArch [AUR]\n Minecraft") in
|
case $(menu "Install" " Steam\n RetroArch [AUR]\n Minecraft") in
|
||||||
*Steam*) present_terminal omarchy-install-steam ;;
|
*Steam*) present_terminal omarchy-install-steam ;;
|
||||||
*RetroArch*) aur_install_and_launch "RetroArch" "retroarch retroarch-assets libretro libretro-fbneo" "com.libretro.RetroArch.desktop" ;;
|
*RetroArch*) aur_install_and_launch "RetroArch" "retroarch retroarch-assets libretro libretro-fbneo" "com.libretro.RetroArch.desktop" ;;
|
||||||
*Minecraft*) install_and_launch "Minecraft" "minecraft-launcher" "minecraft-launcher" ;;
|
*Minecraft*) aur_install_and_launch "Minecraft [AUR]" "minecraft-launcher" "minecraft-launcher" ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -259,7 +327,7 @@ show_install_font_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_install_development_menu() {
|
show_install_development_menu() {
|
||||||
case $(menu "Install" " Ruby on Rails\n Docker DB\n JavaScript\n Go\n PHP\n Python\n Elixir\n Zig\n Rust\n Java\n .NET\n OCaml") in
|
case $(menu "Install" " Ruby on Rails\n Docker DB\n JavaScript\n Go\n PHP\n Python\n Elixir\n Zig\n Rust\n Java\n .NET\n OCaml\n Clojure") in
|
||||||
*Rails*) present_terminal "omarchy-install-dev-env ruby" ;;
|
*Rails*) present_terminal "omarchy-install-dev-env ruby" ;;
|
||||||
*Docker*) present_terminal omarchy-install-docker-dbs ;;
|
*Docker*) present_terminal omarchy-install-docker-dbs ;;
|
||||||
*JavaScript*) show_install_javascript_menu ;;
|
*JavaScript*) show_install_javascript_menu ;;
|
||||||
@@ -272,6 +340,7 @@ show_install_development_menu() {
|
|||||||
*Java*) present_terminal "omarchy-install-dev-env java" ;;
|
*Java*) present_terminal "omarchy-install-dev-env java" ;;
|
||||||
*NET*) present_terminal "omarchy-install-dev-env dotnet" ;;
|
*NET*) present_terminal "omarchy-install-dev-env dotnet" ;;
|
||||||
*OCaml*) present_terminal "omarchy-install-dev-env ocaml" ;;
|
*OCaml*) present_terminal "omarchy-install-dev-env ocaml" ;;
|
||||||
|
*Clojure*) present_terminal "omarchy-install-dev-env clojure" ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -315,16 +384,26 @@ show_remove_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_update_menu() {
|
show_update_menu() {
|
||||||
case $(menu "Update" " Omarchy\n Config\n Themes\n Process\n Timezone") in
|
case $(menu "Update" " Omarchy\n Branch\n Config\n Extra Themes\n Process\n Hardware\n Password\n Timezone") in
|
||||||
*Omarchy*) present_terminal omarchy-update ;;
|
*Omarchy*) present_terminal omarchy-update ;;
|
||||||
|
*Branch*) show_update_branch_menu ;;
|
||||||
*Config*) show_update_config_menu ;;
|
*Config*) show_update_config_menu ;;
|
||||||
*Themes*) present_terminal omarchy-theme-update ;;
|
*Themes*) present_terminal omarchy-theme-update ;;
|
||||||
*Process*) show_update_process_menu ;;
|
*Process*) show_update_process_menu ;;
|
||||||
|
*Hardware*) show_update_hardware_menu ;;
|
||||||
*Timezone*) omarchy-cmd-tzupdate ;;
|
*Timezone*) omarchy-cmd-tzupdate ;;
|
||||||
|
*Password*) show_update_password_menu ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_update_branch_menu() {
|
||||||
|
case $(menu "Branch" "master\ndev" "" "$(omarchy-version-branch)") in
|
||||||
|
*master*) present_terminal "omarchy-update-branch master" ;;
|
||||||
|
*dev*) present_terminal "omarchy-update-branch dev" ;;
|
||||||
|
*) show_update_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
show_update_process_menu() {
|
show_update_process_menu() {
|
||||||
case $(menu "Restart" " Hypridle\n Hyprsunset\n Swayosd\n Walker\n Waybar") in
|
case $(menu "Restart" " Hypridle\n Hyprsunset\n Swayosd\n Walker\n Waybar") in
|
||||||
*Hypridle*) omarchy-restart-hypridle ;;
|
*Hypridle*) omarchy-restart-hypridle ;;
|
||||||
@@ -332,7 +411,7 @@ show_update_process_menu() {
|
|||||||
*Swayosd*) omarchy-restart-swayosd ;;
|
*Swayosd*) omarchy-restart-swayosd ;;
|
||||||
*Walker*) omarchy-restart-walker ;;
|
*Walker*) omarchy-restart-walker ;;
|
||||||
*Waybar*) omarchy-restart-waybar ;;
|
*Waybar*) omarchy-restart-waybar ;;
|
||||||
*) show_main_menu ;;
|
*) show_update_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -346,7 +425,23 @@ show_update_config_menu() {
|
|||||||
*Swayosd*) present_terminal omarchy-refresh-swayosd ;;
|
*Swayosd*) present_terminal omarchy-refresh-swayosd ;;
|
||||||
*Walker*) present_terminal omarchy-refresh-walker ;;
|
*Walker*) present_terminal omarchy-refresh-walker ;;
|
||||||
*Waybar*) present_terminal omarchy-refresh-waybar ;;
|
*Waybar*) present_terminal omarchy-refresh-waybar ;;
|
||||||
*) show_main_menu ;;
|
*) show_update_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_update_hardware_menu() {
|
||||||
|
case $(menu "Restart" " Wi-Fi\n Bluetooth") in
|
||||||
|
*Wi-Fi*) present_terminal omarchy-restart-wifi ;;
|
||||||
|
*Bluetooth*) present_terminal omarchy-restart-bluetooth ;;
|
||||||
|
*) show_update_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_update_password_menu() {
|
||||||
|
case $(menu "Update Password" " Drive Encryption\n User") in
|
||||||
|
*Drive*) present_terminal omarchy-drive-set-password ;;
|
||||||
|
*User*) present_terminal passwd ;;
|
||||||
|
*) show_update_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -358,34 +453,36 @@ show_system_menu() {
|
|||||||
*Relaunch*) uwsm stop ;;
|
*Relaunch*) uwsm stop ;;
|
||||||
*Restart*) systemctl reboot ;;
|
*Restart*) systemctl reboot ;;
|
||||||
*Shutdown*) systemctl poweroff ;;
|
*Shutdown*) systemctl poweroff ;;
|
||||||
*) show_main_menu ;;
|
*) back_to show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_main_menu() {
|
show_main_menu() {
|
||||||
go_to_menu "$(menu "Go" " Apps\n Learn\n Capture\n Toggle\n Style\n Setup\n Install\n Remove\n Update\n About\n System")"
|
go_to_menu "$(menu "Go" " Apps\n Learn\n Trigger\n Style\n Setup\n Install\n Remove\n Update\n About\n System")"
|
||||||
}
|
}
|
||||||
|
|
||||||
go_to_menu() {
|
go_to_menu() {
|
||||||
case "${1,,}" in
|
case "${1,,}" in
|
||||||
*apps*) walker -p "Launch…" ;;
|
*apps*) walker -p "Launch…" ;;
|
||||||
*learn*) show_learn_menu ;;
|
*learn*) show_learn_menu ;;
|
||||||
|
*trigger*) show_trigger_menu ;;
|
||||||
|
*share*) show_share_menu ;;
|
||||||
*style*) show_style_menu ;;
|
*style*) show_style_menu ;;
|
||||||
*theme*) show_theme_menu ;;
|
*theme*) show_theme_menu ;;
|
||||||
*capture*) show_capture_menu ;;
|
|
||||||
*screenshot*) show_screenshot_menu ;;
|
*screenshot*) show_screenshot_menu ;;
|
||||||
*screenrecord*) show_screenrecord_menu ;;
|
*screenrecord*) show_screenrecord_menu ;;
|
||||||
*toggle*) show_toggle_menu ;;
|
|
||||||
*setup*) show_setup_menu ;;
|
*setup*) show_setup_menu ;;
|
||||||
|
*power*) show_setup_power_menu ;;
|
||||||
*install*) show_install_menu ;;
|
*install*) show_install_menu ;;
|
||||||
*remove*) show_remove_menu ;;
|
*remove*) show_remove_menu ;;
|
||||||
*update*) show_update_menu ;;
|
*update*) show_update_menu ;;
|
||||||
|
*about*) omarchy-launch-about ;;
|
||||||
*system*) show_system_menu ;;
|
*system*) show_system_menu ;;
|
||||||
*about*) terminal bash -c 'fastfetch; read -n 1 -s' ;;
|
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
if [[ -n "$1" ]]; then
|
if [[ -n "$1" ]]; then
|
||||||
|
BACK_TO_EXIT=true
|
||||||
go_to_menu "$1"
|
go_to_menu "$1"
|
||||||
else
|
else
|
||||||
show_main_menu
|
show_main_menu
|
||||||
|
|||||||
@@ -83,7 +83,11 @@ parse_bindings() {
|
|||||||
}'
|
}'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
monitor_height=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true) | .height')
|
||||||
|
menu_height=$((monitor_height * 40 / 100))
|
||||||
|
|
||||||
dynamic_bindings | \
|
dynamic_bindings | \
|
||||||
sort -u | \
|
sort -u | \
|
||||||
parse_bindings | \
|
parse_bindings | \
|
||||||
walker --dmenu --theme keybindings -p 'Keybindings'
|
walker --dmenu --theme keybindings -p 'Keybindings' -w 800 -h "$menu_height"
|
||||||
|
|
||||||
|
|||||||
@@ -1,18 +1,27 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
# Where we store an empty file for each migration that has already been performed.
|
# Where we store an empty file for each migration that has already been performed.
|
||||||
STATE_DIR="$HOME/.local/state/omarchy/migrations"
|
STATE_DIR="$HOME/.local/state/omarchy/migrations"
|
||||||
mkdir -p "$STATE_DIR"
|
mkdir -p "$STATE_DIR"
|
||||||
|
|
||||||
|
# Skipped migrations are tracked separately
|
||||||
|
mkdir -p "$STATE_DIR/skipped"
|
||||||
|
|
||||||
# Run any pending migrations
|
# Run any pending migrations
|
||||||
for file in ~/.local/share/omarchy/migrations/*.sh; do
|
for file in ~/.local/share/omarchy/migrations/*.sh; do
|
||||||
filename=$(basename "$file")
|
filename=$(basename "$file")
|
||||||
|
|
||||||
if [[ ! -f "$STATE_DIR/$filename" ]]; then
|
if [[ ! -f "$STATE_DIR/$filename" && ! -f "$STATE_DIR/skipped/$filename" ]]; then
|
||||||
echo -e "\e[32m\nRunning migration (${filename%.sh})\e[0m"
|
echo -e "\e[32m\nRunning migration (${filename%.sh})\e[0m"
|
||||||
source $file
|
|
||||||
touch "$STATE_DIR/$filename"
|
if bash $file; then
|
||||||
|
touch "$STATE_DIR/$filename"
|
||||||
|
else
|
||||||
|
if gum confirm "Migration ${filename%.sh} failed. Skip and continue?"; then
|
||||||
|
touch "$STATE_DIR/skipped/$filename"
|
||||||
|
else
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|||||||
13
bin/omarchy-notification-dismiss
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-notification-dismiss <summary>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Find the first notification whose 'summary' matches the regex in $1
|
||||||
|
notification_id=$(makoctl list | grep -F "$1" | head -n1 | sed -E 's/^Notification ([0-9]+):.*/\1/')
|
||||||
|
|
||||||
|
if [[ -n $notification_id ]]; then
|
||||||
|
makoctl dismiss -n $notification_id
|
||||||
|
fi
|
||||||
9
bin/omarchy-pkg-add
Executable file
@@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for pkg in "$@"; do
|
||||||
|
if ! pacman -Q "$pkg" &>/dev/null; then
|
||||||
|
sudo pacman -S --noconfirm "$pkg" || exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 0
|
||||||
@@ -1,25 +1,24 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'yay -Sii {1}'
|
--preview 'yay -Siia {1}'
|
||||||
--preview-label='alt-p: toggle description, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
--preview-label='alt-p: toggle description, alt-b/B: toggle PKGBUILD, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
||||||
--preview-label-pos='bottom'
|
--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'
|
||||||
|
--bind 'alt-b:change-preview:yay -Gpa {1} | tail -n +5'
|
||||||
|
--bind 'alt-B:change-preview:yay -Siia {1}'
|
||||||
--color 'pointer:green,marker:green'
|
--color 'pointer:green,marker:green'
|
||||||
)
|
)
|
||||||
|
|
||||||
yay -Sy
|
|
||||||
pkg_names=$(yay -Slqa | fzf "${fzf_args[@]}")
|
pkg_names=$(yay -Slqa | fzf "${fzf_args[@]}")
|
||||||
|
|
||||||
if [[ -n "$pkg_names" ]]; then
|
if [[ -n "$pkg_names" ]]; then
|
||||||
# Convert newline-separated selections to space-separated for yay
|
# Convert newline-separated selections to space-separated for yay
|
||||||
echo "$pkg_names" | tr '\n' ' ' | xargs yay -Sy --noconfirm
|
echo "$pkg_names" | tr '\n' ' ' | xargs yay -S --noconfirm
|
||||||
sudo updatedb
|
sudo updatedb
|
||||||
omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
|||||||
7
bin/omarchy-pkg-drop
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for pkg in "$@"; do
|
||||||
|
if pacman -Q "$pkg" &>/dev/null; then
|
||||||
|
sudo pacman -Rns --noconfirm "$pkg"
|
||||||
|
fi
|
||||||
|
done
|
||||||
7
bin/omarchy-pkg-ignored
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
IGNORED_PACKAGES_FILE="$OMARCHY_PATH/install/packages.ignored"
|
||||||
|
|
||||||
|
if [[ -f $IGNORED_PACKAGES_FILE ]]; then
|
||||||
|
tr '\r\n' ',' <"$IGNORED_PACKAGES_FILE" | sed 's/,$//'
|
||||||
|
fi
|
||||||
@@ -1,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'pacman -Sii {1}'
|
--preview 'pacman -Sii {1}'
|
||||||
@@ -14,12 +12,10 @@ fzf_args=(
|
|||||||
--color 'pointer:green,marker:green'
|
--color 'pointer:green,marker:green'
|
||||||
)
|
)
|
||||||
|
|
||||||
sudo pacman -Sy
|
|
||||||
pkg_names=$(pacman -Slq | fzf "${fzf_args[@]}")
|
pkg_names=$(pacman -Slq | fzf "${fzf_args[@]}")
|
||||||
|
|
||||||
if [[ -n "$pkg_names" ]]; then
|
if [[ -n "$pkg_names" ]]; then
|
||||||
# Convert newline-separated selections to space-separated for yay
|
# Convert newline-separated selections to space-separated for yay
|
||||||
echo "$pkg_names" | tr '\n' ' ' | xargs sudo pacman -Sy --noconfirm
|
echo "$pkg_names" | tr '\n' ' ' | xargs sudo pacman -S --noconfirm
|
||||||
sudo updatedb
|
|
||||||
omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
|||||||
9
bin/omarchy-pkg-missing
Executable file
@@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for pkg in "$@"; do
|
||||||
|
if ! pacman -Q "$pkg" &>/dev/null; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 1
|
||||||
7
bin/omarchy-pkg-pinned
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
PINNED_PACKAGES_FILE="$OMARCHY_PATH/install/packages.pinned"
|
||||||
|
|
||||||
|
if [[ -f $PINNED_PACKAGES_FILE ]]; then
|
||||||
|
tr '\r\n' ',' <"$PINNED_PACKAGES_FILE" | sed 's/,$//'
|
||||||
|
fi
|
||||||
7
bin/omarchy-pkg-present
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
for pkg in "$@"; do
|
||||||
|
pacman -Q "$pkg" &>/dev/null || exit 1
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 0
|
||||||
@@ -17,6 +17,5 @@ pkg_names=$(yay -Qqe | fzf "${fzf_args[@]}")
|
|||||||
if [[ -n "$pkg_names" ]]; then
|
if [[ -n "$pkg_names" ]]; then
|
||||||
# Convert newline-separated selections to space-separated for yay
|
# Convert newline-separated selections to space-separated for yay
|
||||||
echo "$pkg_names" | tr '\n' ' ' | xargs sudo pacman -Rns --noconfirm
|
echo "$pkg_names" | tr '\n' ' ' | xargs sudo pacman -Rns --noconfirm
|
||||||
sudo updatedb
|
|
||||||
omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
|||||||
3
bin/omarchy-refresh-fastfetch
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
omarchy-refresh-config fastfetch/config.jsonc
|
||||||
3
bin/omarchy-refresh-pacman-mirrorlist
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
sudo cp -f ~/.local/share/omarchy/default/pacman/mirrorlist /etc/pacman.d/mirrorlist
|
||||||
@@ -1,6 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [[ "$1" == "-y" ]]; then
|
sudo cp ~/.local/share/omarchy/default/plymouth/* /usr/share/plymouth/themes/omarchy/
|
||||||
sudo cp ~/.local/share/omarchy/default/plymouth/* /usr/share/plymouth/themes/omarchy/
|
sudo plymouth-set-default-theme omarchy
|
||||||
sudo plymouth-set-default-theme -R omarchy
|
|
||||||
|
if command -v limine-mkinitcpio &>/dev/null; then
|
||||||
|
sudo limine-mkinitcpio
|
||||||
|
else
|
||||||
|
sudo mkinitcpio -P
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo "Resetting sudo lockout for user: $USER"
|
# Resetting sudo lockout for user
|
||||||
su -c "faillock --reset --user $USER"
|
su -c "faillock --reset --user $USER"
|
||||||
|
|||||||
4
bin/omarchy-restart-bluetooth
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
rfkill unblock bluetooth
|
||||||
|
rfkill list bluetooth
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
pkill walker
|
pkill walker
|
||||||
# FIXME: Reenable the walker service once the memory leak has been fixed
|
# FIXME: Just deal with the memory leak for now.
|
||||||
# See https://github.com/basecamp/omarchy/issues/698
|
# See https://github.com/basecamp/omarchy/issues/698
|
||||||
# setsid uwsm app -- walker --gapplication-service &
|
setsid uwsm app -- walker --gapplication-service &
|
||||||
echo # Always end in success so we don't terminate further running
|
echo # Always end in success so we don't terminate further running
|
||||||
|
|||||||
4
bin/omarchy-restart-wifi
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
rfkill unblock wifi
|
||||||
|
rfkill list wifi
|
||||||
@@ -37,8 +37,6 @@ EOF
|
|||||||
DHCP)
|
DHCP)
|
||||||
sudo tee /etc/systemd/resolved.conf >/dev/null <<'EOF'
|
sudo tee /etc/systemd/resolved.conf >/dev/null <<'EOF'
|
||||||
[Resolve]
|
[Resolve]
|
||||||
DNS=
|
|
||||||
FallbackDNS=
|
|
||||||
DNSOverTLS=no
|
DNSOverTLS=no
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
|||||||
@@ -16,9 +16,15 @@ case "$COMMAND" in
|
|||||||
create)
|
create)
|
||||||
DESC="$(omarchy-version)"
|
DESC="$(omarchy-version)"
|
||||||
|
|
||||||
for config in root home; do
|
echo -e "\e[32mCreate system snapshot\e[0m"
|
||||||
|
|
||||||
|
# Get existing snapper config names from CSV output
|
||||||
|
mapfile -t CONFIGS < <(sudo snapper --csvout list-configs | awk -F, 'NR>1 {print $1}')
|
||||||
|
|
||||||
|
for config in "${CONFIGS[@]}"; do
|
||||||
sudo snapper -c "$config" create -c number -d "$DESC"
|
sudo snapper -c "$config" create -c number -d "$DESC"
|
||||||
done
|
done
|
||||||
|
echo
|
||||||
;;
|
;;
|
||||||
restore)
|
restore)
|
||||||
sudo limine-snapper-restore
|
sudo limine-snapper-restore
|
||||||
|
|||||||
@@ -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
|
|
||||||
@@ -1,10 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# omarchy-theme-set: Set a theme, specified by its name.
|
if [[ -z $1 && $1 != "CNCLD" ]]; then
|
||||||
# Usage: omarchy-theme-set <theme-name>
|
echo "Usage: omarchy-theme-set <theme-name>"
|
||||||
|
|
||||||
if [[ -z "$1" && "$1" != "CNCLD" ]]; then
|
|
||||||
echo "Usage: omarchy-theme-set <theme-name>" >&2
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -16,54 +13,26 @@ THEME_PATH="$THEMES_DIR/$THEME_NAME"
|
|||||||
|
|
||||||
# Check if the theme entered exists
|
# Check if the theme entered exists
|
||||||
if [[ ! -d "$THEME_PATH" ]]; then
|
if [[ ! -d "$THEME_PATH" ]]; then
|
||||||
echo "Theme '$THEME_NAME' does not exist in $THEMES_DIR" >&2
|
echo "Theme '$THEME_NAME' does not exist in $THEMES_DIR"
|
||||||
exit 2
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Update theme symlinks
|
# Update theme symlinks
|
||||||
ln -nsf "$THEME_PATH" "$CURRENT_THEME_DIR"
|
ln -nsf "$THEME_PATH" "$CURRENT_THEME_DIR"
|
||||||
|
|
||||||
# Change gnome modes
|
# Change background with theme
|
||||||
if [[ -f ~/.config/omarchy/current/theme/light.mode ]]; then
|
omarchy-theme-bg-next
|
||||||
gsettings set org.gnome.desktop.interface color-scheme "prefer-light"
|
|
||||||
gsettings set org.gnome.desktop.interface gtk-theme "Adwaita"
|
|
||||||
else
|
|
||||||
gsettings set org.gnome.desktop.interface color-scheme "prefer-dark"
|
|
||||||
gsettings set org.gnome.desktop.interface gtk-theme "Adwaita-dark"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Change gnome icon theme color
|
|
||||||
if [[ -f ~/.config/omarchy/current/theme/icons.theme ]]; then
|
|
||||||
gsettings set org.gnome.desktop.interface icon-theme "$(<~/.config/omarchy/current/theme/icons.theme)"
|
|
||||||
else
|
|
||||||
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Change Chromium colors
|
|
||||||
if command -v chromium &>/dev/null; then
|
|
||||||
if [[ -f ~/.config/omarchy/current/theme/light.mode ]]; then
|
|
||||||
chromium --no-startup-window --set-color-scheme="light"
|
|
||||||
else
|
|
||||||
chromium --no-startup-window --set-color-scheme="dark"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -f ~/.config/omarchy/current/theme/chromium.theme ]]; 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
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Trigger alacritty config reload
|
|
||||||
touch "$HOME/.config/alacritty/alacritty.toml"
|
|
||||||
|
|
||||||
# Restart components to apply new theme
|
# Restart components to apply new theme
|
||||||
pkill -SIGUSR2 btop
|
|
||||||
omarchy-restart-waybar
|
omarchy-restart-waybar
|
||||||
omarchy-restart-swayosd
|
omarchy-restart-swayosd
|
||||||
makoctl reload
|
|
||||||
hyprctl reload
|
hyprctl reload
|
||||||
|
pkill -SIGUSR2 btop
|
||||||
|
makoctl reload
|
||||||
|
|
||||||
# Set new background
|
# Change gnome, browser, vscode themes
|
||||||
omarchy-theme-bg-next
|
omarchy-theme-set-terminal
|
||||||
|
omarchy-theme-set-gnome
|
||||||
|
omarchy-theme-set-eza
|
||||||
|
omarchy-theme-set-browser
|
||||||
|
omarchy-theme-set-vscode
|
||||||
|
|||||||
23
bin/omarchy-theme-set-browser
Executable file
@@ -0,0 +1,23 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
CHROMIUM_THEME=~/.config/omarchy/current/theme/chromium.theme
|
||||||
|
|
||||||
|
if omarchy-cmd-present chromium || omarchy-cmd-present brave; then
|
||||||
|
if [[ -f $CHROMIUM_THEME ]]; then
|
||||||
|
rgb=$(<$CHROMIUM_THEME)
|
||||||
|
THEME_HEX_COLOR=$(printf '#%02x%02x%02x' ${rgb//,/ })
|
||||||
|
else
|
||||||
|
# Use a default, neutral grey if theme doesn't have a color
|
||||||
|
THEME_HEX_COLOR="#1c2027"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if omarchy-cmd-present chromium; then
|
||||||
|
echo "{\"BrowserThemeColor\": \"$THEME_HEX_COLOR\"}" | tee "/etc/chromium/policies/managed/color.json" >/dev/null
|
||||||
|
chromium --refresh-platform-policy --no-startup-window
|
||||||
|
fi
|
||||||
|
|
||||||
|
if omarchy-cmd-present brave; then
|
||||||
|
echo "{\"BrowserThemeColor\": \"$THEME_HEX_COLOR\"}" | tee "/etc/brave/policies/managed/color.json" >/dev/null
|
||||||
|
brave --refresh-platform-policy --no-startup-window
|
||||||
|
fi
|
||||||
|
fi
|
||||||
7
bin/omarchy-theme-set-eza
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ -f ~/.config/omarchy/current/theme/eza.yml ]; then
|
||||||
|
ln -snf ~/.config/omarchy/current/theme/eza.yml ~/.config/eza/theme.yml
|
||||||
|
else
|
||||||
|
rm -f ~/.config/eza/theme.yml
|
||||||
|
fi
|
||||||
18
bin/omarchy-theme-set-gnome
Executable file
@@ -0,0 +1,18 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Change gnome modes
|
||||||
|
if [[ -f ~/.config/omarchy/current/theme/light.mode ]]; then
|
||||||
|
gsettings set org.gnome.desktop.interface color-scheme "prefer-light"
|
||||||
|
gsettings set org.gnome.desktop.interface gtk-theme "Adwaita"
|
||||||
|
else
|
||||||
|
gsettings set org.gnome.desktop.interface color-scheme "prefer-dark"
|
||||||
|
gsettings set org.gnome.desktop.interface gtk-theme "Adwaita-dark"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Change gnome icon theme color
|
||||||
|
GNOME_ICONS_THEME=~/.config/omarchy/current/theme/icons.theme
|
||||||
|
if [[ -f $GNOME_ICONS_THEME ]]; then
|
||||||
|
gsettings set org.gnome.desktop.interface icon-theme "$(<$GNOME_ICONS_THEME)"
|
||||||
|
else
|
||||||
|
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
||||||
|
fi
|
||||||
7
bin/omarchy-theme-set-terminal
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
case "$TERMINAL" in
|
||||||
|
"alacritty") touch ~/.config/alacritty/alacritty.toml ;;
|
||||||
|
"kitty") killall -SIGUSR1 kitty ;;
|
||||||
|
"ghostty") killall -SIGUSR2 ghostty ;;
|
||||||
|
esac
|
||||||
26
bin/omarchy-theme-set-vscode
Executable file
@@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
VS_CODE_THEME="$HOME/.config/omarchy/current/theme/vscode.json"
|
||||||
|
VS_CODE_SETTINGS="$HOME/.config/Code/User/settings.json"
|
||||||
|
VS_CODE_SKIP_FLAG="$HOME/.local/state/omarchy/toggles/skip-vscode-theme-changes"
|
||||||
|
|
||||||
|
if omarchy-cmd-present code && [[ ! -f "$VS_CODE_SKIP_FLAG" ]]; then
|
||||||
|
if [[ -f "$VS_CODE_THEME" ]]; then
|
||||||
|
theme_name=$(jq -r '.name' "$VS_CODE_THEME")
|
||||||
|
extension=$(jq -r '.extension' "$VS_CODE_THEME")
|
||||||
|
|
||||||
|
# Install VS Code theme extension
|
||||||
|
if [[ -n "$extension" ]] && ! code --list-extensions | grep -Fxq "$extension"; then
|
||||||
|
notify-send " Installing VS Code theme for $theme_name"
|
||||||
|
code --install-extension "$extension" >/dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Update theme in settings.json
|
||||||
|
jq -n --arg t "$theme_name" '(input? // {}) | .["workbench.colorTheme"] = $t' "$VS_CODE_SETTINGS" >"${VS_CODE_SETTINGS}.new"
|
||||||
|
else
|
||||||
|
# Remove theme from settings.json when the theme doesn't have vscode support
|
||||||
|
jq 'del(.["workbench.colorTheme"])' "$VS_CODE_SETTINGS" >"${VS_CODE_SETTINGS}.new"
|
||||||
|
fi
|
||||||
|
|
||||||
|
mv "${VS_CODE_SETTINGS}.new" "$VS_CODE_SETTINGS"
|
||||||
|
fi
|
||||||
@@ -20,13 +20,16 @@ fi
|
|||||||
|
|
||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
DESKTOP_FILE="$HOME/.local/share/applications/$APP_NAME.desktop"
|
DESKTOP_FILE="$HOME/.local/share/applications/$APP_NAME.desktop"
|
||||||
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
|
||||||
|
|
||||||
mkdir -p "$ICON_DIR"
|
if [[ ! "$ICON_URL" =~ ^https?:// ]] && [ -f "$ICON_URL" ]; then
|
||||||
|
ICON_PATH="$ICON_URL"
|
||||||
if ! curl -sL -o "$ICON_PATH" "$ICON_URL"; then
|
else
|
||||||
echo "Error: Failed to download icon."
|
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
||||||
return 1
|
mkdir -p "$ICON_DIR"
|
||||||
|
if ! curl -sL -o "$ICON_PATH" "$ICON_URL"; then
|
||||||
|
echo "Error: Failed to download icon."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ $WINDOW_STYLE == "float" ]]; then
|
if [[ $WINDOW_STYLE == "float" ]]; then
|
||||||
@@ -40,7 +43,7 @@ cat >"$DESKTOP_FILE" <<EOF
|
|||||||
Version=1.0
|
Version=1.0
|
||||||
Name=$APP_NAME
|
Name=$APP_NAME
|
||||||
Comment=$APP_NAME
|
Comment=$APP_NAME
|
||||||
Exec=alacritty --class $APP_CLASS -e $APP_EXEC
|
Exec=$TERMINAL --class $APP_CLASS -e $APP_EXEC
|
||||||
Terminal=false
|
Terminal=false
|
||||||
Type=Application
|
Type=Application
|
||||||
Icon=$ICON_PATH
|
Icon=$ICON_PATH
|
||||||
|
|||||||
@@ -3,10 +3,10 @@
|
|||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
DESKTOP_DIR="$HOME/.local/share/applications/"
|
DESKTOP_DIR="$HOME/.local/share/applications/"
|
||||||
|
|
||||||
if [ "$#" -ne 1 ]; then
|
if [ "$#" -eq 0 ]; then
|
||||||
# Find all web apps
|
# Find all TUIs
|
||||||
while IFS= read -r -d '' file; do
|
while IFS= read -r -d '' file; do
|
||||||
if grep -q '^Exec=.*alacritty.*-e' "$file"; then
|
if grep -q '^Exec=.*$TERMINAL.*-e' "$file"; then
|
||||||
TUIS+=("$(basename "${file%.desktop}")")
|
TUIS+=("$(basename "${file%.desktop}")")
|
||||||
fi
|
fi
|
||||||
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
||||||
@@ -14,23 +14,28 @@ if [ "$#" -ne 1 ]; then
|
|||||||
if ((${#TUIS[@]})); then
|
if ((${#TUIS[@]})); then
|
||||||
IFS=$'\n' SORTED_TUIS=($(sort <<<"${TUIS[*]}"))
|
IFS=$'\n' SORTED_TUIS=($(sort <<<"${TUIS[*]}"))
|
||||||
unset IFS
|
unset IFS
|
||||||
APP_NAME=$(gum choose --header "Select TUI to remove..." "${SORTED_TUIS[@]}")
|
APP_NAMES_STRING=$(gum choose --no-limit --header "Select TUI to remove..." --selected-prefix="✗ " "${SORTED_TUIS[@]}")
|
||||||
|
# Convert newline-separated string to array
|
||||||
|
APP_NAMES=()
|
||||||
|
while IFS= read -r line; do
|
||||||
|
[[ -n "$line" ]] && APP_NAMES+=("$line")
|
||||||
|
done <<< "$APP_NAMES_STRING"
|
||||||
else
|
else
|
||||||
echo "No TUIs to remove."
|
echo "No TUIs to remove."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
APP_NAME="$1"
|
# Use array to preserve spaces in app names
|
||||||
|
APP_NAMES=("$@")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "$APP_NAME" ]]; then
|
if [[ ${#APP_NAMES[@]} -eq 0 ]]; then
|
||||||
echo "You must provide TUI name."
|
echo "You must provide TUI names."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm "$DESKTOP_DIR/$APP_NAME.desktop"
|
for APP_NAME in "${APP_NAMES[@]}"; do
|
||||||
rm "$ICON_DIR/$APP_NAME.png"
|
rm -f "$DESKTOP_DIR/$APP_NAME.desktop"
|
||||||
|
rm -f "$ICON_DIR/$APP_NAME.png"
|
||||||
if [ "$#" -ne 1 ]; then
|
echo "Removed $APP_NAME"
|
||||||
echo -e "Removed $APP_NAME\n"
|
done
|
||||||
fi
|
|
||||||
|
|||||||
@@ -4,7 +4,4 @@ set -e
|
|||||||
|
|
||||||
omarchy-snapshot create || [ $? -eq 127 ]
|
omarchy-snapshot create || [ $? -eq 127 ]
|
||||||
omarchy-update-git
|
omarchy-update-git
|
||||||
omarchy-migrate
|
omarchy-update-perform
|
||||||
omarchy-update-system-pkgs
|
|
||||||
omarchy-update-restart
|
|
||||||
omarchy-restart-waybar # removes update-available icon
|
|
||||||
|
|||||||
@@ -1,13 +1,18 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Ensure remote is reachable
|
# Get remote tag
|
||||||
if ! git -C "$OMARCHY_PATH" ls-remote &>/dev/null; then
|
latest_tag=$(git -C "$OMARCHY_PATH" ls-remote --tags origin | grep -v "{}" | awk '{print $2}' | sed 's#refs/tags/##' | sort -V | tail -n 1)
|
||||||
echo "Error: Unable to reach remote repository."
|
if [[ -z "$latest_tag" ]]; then
|
||||||
|
echo "Error: Could not retrieve latest tag."
|
||||||
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)
|
# Get local tag
|
||||||
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 [[ -z "$current_tag" ]]; then
|
||||||
|
echo "Error: Could not retrieve current tag."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
if [[ "$current_tag" != "$latest_tag" ]]; then
|
if [[ "$current_tag" != "$latest_tag" ]]; then
|
||||||
echo "Omarchy update available ($latest_tag)"
|
echo "Omarchy update available ($latest_tag)"
|
||||||
|
|||||||
4
bin/omarchy-update-available-reset
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Ensure Waybar icon offering the available update is removed
|
||||||
|
pkill -RTMIN+7 waybar
|
||||||
33
bin/omarchy-update-branch
Executable file
@@ -0,0 +1,33 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-verion-branch-set [master|dev]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
branch="$1"
|
||||||
|
|
||||||
|
# Snapshot before switching branch
|
||||||
|
omarchy-snapshot create || [ $? -eq 127 ]
|
||||||
|
|
||||||
|
if ! git -C "$OMARCHY_PATH" diff --quiet || ! git -C "$OMARCHY_PATH" diff --cached --quiet; then
|
||||||
|
stashed=true
|
||||||
|
git -C "$OMARCHY_PATH" stash push -u -m "Autostash before switching to $branch"
|
||||||
|
else
|
||||||
|
stashed=false
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Switch branches
|
||||||
|
git -C "$OMARCHY_PATH" switch "$branch"
|
||||||
|
|
||||||
|
# Reapply stash if we made one
|
||||||
|
if [[ $stashed == true ]]; then
|
||||||
|
if ! git -C "$OMARCHY_PATH" stash pop; then
|
||||||
|
echo "⚠️ Conflicts when applying stash — stash kept"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Update the system from the new branch
|
||||||
|
omarchy-update-perform
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo -e "\e[32mUpdate Omarchy\e[0m"
|
echo -e "\e[32mUpdate Omarchy\e[0m"
|
||||||
|
|
||||||
git -C $OMARCHY_PATH pull --autostash
|
git -C $OMARCHY_PATH pull --autostash
|
||||||
git -C $OMARCHY_PATH diff --check || git -C $OMARCHY_PATH reset --merge
|
git -C $OMARCHY_PATH diff --check || git -C $OMARCHY_PATH reset --merge
|
||||||
|
|||||||
8
bin/omarchy-update-perform
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
omarchy-update-available-reset
|
||||||
|
omarchy-update-system-pkgs
|
||||||
|
omarchy-migrate
|
||||||
|
omarchy-update-restart
|
||||||
@@ -1,16 +1,24 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo -e "\e[32m\nUpdate system packages\e[0m"
|
# Used in package emergencies if a bad package has been pushed and we can't revoke.
|
||||||
sudo pacman -Syu --noconfirm
|
# Requires manually installing the good package using sudo pacman -U <url>
|
||||||
echo
|
ignored_packages=$(omarchy-pkg-ignored)
|
||||||
|
|
||||||
if omarchy-pkg-aur-accessible; then
|
echo -e "\e[32m\nUpdate system packages\e[0m"
|
||||||
echo -e "\e[32m\nUpdate AUR packages\e[0m"
|
[[ -n $ignored_packages ]] && echo "sudo pacman -Syu --noconfirm --ignore \"$ignored_packages\""
|
||||||
yay -Syu --noconfirm
|
sudo pacman -Syu --noconfirm --ignore "$ignored_packages"
|
||||||
echo
|
|
||||||
else
|
# Update AUR packages if any are installed
|
||||||
echo -e "\e[31m\nAUR is unavailable (so skipping updates)\e[0m"
|
if pacman -Qem >/dev/null; then
|
||||||
echo
|
if omarchy-pkg-aur-accessible; then
|
||||||
|
echo -e "\e[32m\nUpdate AUR packages\e[0m"
|
||||||
|
[[ -n $ignored_packages ]] && echo "yay -Sua --noconfirm --ignore \"$ignored_packages\""
|
||||||
|
yay -Sua --noconfirm --ignore "$ignored_packages"
|
||||||
|
echo
|
||||||
|
else
|
||||||
|
echo -e "\e[31m\nAUR is unavailable (so skipping updates)\e[0m"
|
||||||
|
echo
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
orphans=$(pacman -Qtdq)
|
orphans=$(pacman -Qtdq)
|
||||||
|
|||||||
126
bin/omarchy-upload-log
Executable file
@@ -0,0 +1,126 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Upload logs to 0x0.st
|
||||||
|
|
||||||
|
LOG_TYPE="${1:-install}"
|
||||||
|
TEMP_LOG="/tmp/upload-log.txt"
|
||||||
|
SYSTEM_INFO="/tmp/system-info.txt"
|
||||||
|
|
||||||
|
# Get system information if fastfetch is available
|
||||||
|
if command -v fastfetch >/dev/null 2>&1; then
|
||||||
|
{
|
||||||
|
echo "========================================="
|
||||||
|
echo "SYSTEM INFORMATION"
|
||||||
|
echo "========================================="
|
||||||
|
# Use fastfetch with no logo to get clean output
|
||||||
|
fastfetch --logo none --pipe 2>/dev/null || echo "Failed to get system info"
|
||||||
|
echo ""
|
||||||
|
echo "========================================="
|
||||||
|
echo "LOG CONTENT"
|
||||||
|
echo "========================================="
|
||||||
|
echo ""
|
||||||
|
} >"$SYSTEM_INFO"
|
||||||
|
else
|
||||||
|
# Fallback to basic info if fastfetch isn't available
|
||||||
|
{
|
||||||
|
echo "========================================="
|
||||||
|
echo "SYSTEM INFORMATION"
|
||||||
|
echo "========================================="
|
||||||
|
echo "Hostname: $(hostname)"
|
||||||
|
echo "Kernel: $(uname -r)"
|
||||||
|
echo "Date: $(date)"
|
||||||
|
echo ""
|
||||||
|
echo "========================================="
|
||||||
|
echo "LOG CONTENT"
|
||||||
|
echo "========================================="
|
||||||
|
echo ""
|
||||||
|
} >"$SYSTEM_INFO"
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$LOG_TYPE" in
|
||||||
|
install)
|
||||||
|
ARCHINSTALL_LOG="/var/log/archinstall/install.log"
|
||||||
|
OMARCHY_LOG="/var/log/omarchy-install.log"
|
||||||
|
|
||||||
|
# Combine system info with logs
|
||||||
|
cat "$SYSTEM_INFO" >"$TEMP_LOG"
|
||||||
|
cat $ARCHINSTALL_LOG $OMARCHY_LOG >>"$TEMP_LOG" 2>/dev/null
|
||||||
|
|
||||||
|
if [ ! -s "$TEMP_LOG" ]; then
|
||||||
|
echo "Error: No install logs found"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Uploading installation log to 0x0.st..."
|
||||||
|
;;
|
||||||
|
|
||||||
|
this-boot)
|
||||||
|
# Combine system info with boot logs
|
||||||
|
cat "$SYSTEM_INFO" >"$TEMP_LOG"
|
||||||
|
journalctl -b 0 >>"$TEMP_LOG" 2>/dev/null
|
||||||
|
|
||||||
|
if [ ! -s "$TEMP_LOG" ]; then
|
||||||
|
echo "Error: No logs found for current boot"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Uploading current boot logs to 0x0.st..."
|
||||||
|
;;
|
||||||
|
|
||||||
|
last-boot)
|
||||||
|
# Combine system info with previous boot logs
|
||||||
|
cat "$SYSTEM_INFO" >"$TEMP_LOG"
|
||||||
|
journalctl -b -1 >>"$TEMP_LOG" 2>/dev/null
|
||||||
|
|
||||||
|
if [ ! -s "$TEMP_LOG" ]; then
|
||||||
|
echo "Error: No logs found for previous boot"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Uploading previous boot logs to 0x0.st..."
|
||||||
|
;;
|
||||||
|
|
||||||
|
installed)
|
||||||
|
# System info plus all installed packages
|
||||||
|
cat "$SYSTEM_INFO" >"$TEMP_LOG"
|
||||||
|
{
|
||||||
|
echo ""
|
||||||
|
echo "========================================="
|
||||||
|
echo "INSTALLED PACKAGES (pacman -Q)"
|
||||||
|
echo "========================================="
|
||||||
|
pacman -Q 2>/dev/null || echo "Failed to get package list"
|
||||||
|
} >>"$TEMP_LOG"
|
||||||
|
|
||||||
|
if [ ! -s "$TEMP_LOG" ]; then
|
||||||
|
echo "Error: Failed to gather system information"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Uploading system information to 0x0.st..."
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "Usage: $0 [install|this-boot|last-boot|system-info]"
|
||||||
|
echo " install - Upload installation logs (default)"
|
||||||
|
echo " this-boot - Upload logs from current boot"
|
||||||
|
echo " last-boot - Upload logs from previous boot"
|
||||||
|
echo " installed - Upload system info and installed packages"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
URL=$(curl -sF "file=@$TEMP_LOG" -Fexpires=24 https://0x0.st)
|
||||||
|
|
||||||
|
if [ $? -eq 0 ] && [ -n "$URL" ]; then
|
||||||
|
echo "✓ Log uploaded successfully!"
|
||||||
|
echo "Share this URL:"
|
||||||
|
echo ""
|
||||||
|
echo " $URL"
|
||||||
|
echo ""
|
||||||
|
echo "This link will expire in 24 hours."
|
||||||
|
else
|
||||||
|
echo "Error: Failed to upload log file"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
3
bin/omarchy-version-branch
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo $(git -C "$OMARCHY_PATH" rev-parse --abbrev-ref HEAD)
|
||||||
20
bin/omarchy-webapp-handler-zoom
Executable file
@@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
url="$1"
|
||||||
|
web_url="https://app.zoom.us/wc/home"
|
||||||
|
|
||||||
|
if [[ $url =~ ^zoom(mtg|us):// ]]; then
|
||||||
|
confno=$(echo "$url" | sed -n 's/.*[?&]confno=\([^&]*\).*/\1/p')
|
||||||
|
|
||||||
|
if [[ -n $confno ]]; then
|
||||||
|
pwd=$(echo "$url" | sed -n 's/.*[?&]pwd=\([^&]*\).*/\1/p')
|
||||||
|
|
||||||
|
if [[ -n $pwd ]]; then
|
||||||
|
web_url="https://app.zoom.us/wc/join/$confno?pwd=$pwd"
|
||||||
|
else
|
||||||
|
web_url="https://app.zoom.us/wc/join/$confno"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec omarchy-launch-webapp "$web_url"
|
||||||
@@ -1,46 +1,71 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [ "$#" -ne 3 ]; then
|
if [ "$#" -lt 3 ]; then
|
||||||
echo -e "\e[32mLet's create a new web app you can start with the app launcher.\n\e[0m"
|
echo -e "\e[32mLet's create a new web app you can start with the app launcher.\n\e[0m"
|
||||||
APP_NAME=$(gum input --prompt "Name> " --placeholder "My favorite web app")
|
APP_NAME=$(gum input --prompt "Name> " --placeholder "My favorite web app")
|
||||||
APP_URL=$(gum input --prompt "URL> " --placeholder "https://example.com")
|
APP_URL=$(gum input --prompt "URL> " --placeholder "https://example.com")
|
||||||
ICON_URL=$(gum input --prompt "Icon URL> " --placeholder "See https://dashboardicons.com (must use PNG!)")
|
ICON_REF=$(gum input --prompt "Icon URL> " --placeholder "See https://dashboardicons.com (must use PNG!)")
|
||||||
|
CUSTOM_EXEC=""
|
||||||
|
MIME_TYPES=""
|
||||||
|
INTERACTIVE_MODE=true
|
||||||
else
|
else
|
||||||
APP_NAME="$1"
|
APP_NAME="$1"
|
||||||
APP_URL="$2"
|
APP_URL="$2"
|
||||||
ICON_URL="$3"
|
ICON_REF="$3"
|
||||||
|
CUSTOM_EXEC="$4" # Optional custom exec command
|
||||||
|
MIME_TYPES="$5" # Optional mime types
|
||||||
|
INTERACTIVE_MODE=false
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "$APP_NAME" || -z "$APP_URL" || -z "$ICON_URL" ]]; then
|
# Ensure valid execution
|
||||||
|
if [[ -z "$APP_NAME" || -z "$APP_URL" || -z "$ICON_REF" ]]; then
|
||||||
echo "You must set app name, app URL, and icon URL!"
|
echo "You must set app name, app URL, and icon URL!"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Refer to local icon or fetch remotely from URL
|
||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
DESKTOP_FILE="$HOME/.local/share/applications/$APP_NAME.desktop"
|
if [[ $ICON_REF =~ ^https?:// ]]; then
|
||||||
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
||||||
|
if curl -sL -o "$ICON_PATH" "$ICON_REF"; then
|
||||||
mkdir -p "$ICON_DIR"
|
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
||||||
|
else
|
||||||
if ! curl -sL -o "$ICON_PATH" "$ICON_URL"; then
|
echo "Error: Failed to download icon."
|
||||||
echo "Error: Failed to download icon."
|
exit 1
|
||||||
return 1
|
fi
|
||||||
|
else
|
||||||
|
ICON_PATH="$ICON_DIR/$ICON_REF"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Use custom exec if provided, otherwise default behavior
|
||||||
|
if [[ -n $CUSTOM_EXEC ]]; then
|
||||||
|
EXEC_COMMAND="$CUSTOM_EXEC"
|
||||||
|
else
|
||||||
|
EXEC_COMMAND="omarchy-launch-webapp $APP_URL"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create application .desktop file
|
||||||
|
DESKTOP_FILE="$HOME/.local/share/applications/$APP_NAME.desktop"
|
||||||
|
|
||||||
cat >"$DESKTOP_FILE" <<EOF
|
cat >"$DESKTOP_FILE" <<EOF
|
||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
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=$EXEC_COMMAND
|
||||||
Terminal=false
|
Terminal=false
|
||||||
Type=Application
|
Type=Application
|
||||||
Icon=$ICON_PATH
|
Icon=$ICON_PATH
|
||||||
StartupNotify=true
|
StartupNotify=true
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
# Add mime types if provided
|
||||||
|
if [[ -n $MIME_TYPES ]]; then
|
||||||
|
echo "MimeType=$MIME_TYPES" >>"$DESKTOP_FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
chmod +x "$DESKTOP_FILE"
|
chmod +x "$DESKTOP_FILE"
|
||||||
|
|
||||||
if [ "$#" -ne 3 ]; then
|
if [[ $INTERACTIVE_MODE == true ]]; then
|
||||||
echo -e "You can now find $APP_NAME using the app launcher (SUPER + SPACE)\n"
|
echo -e "You can now find $APP_NAME using the app launcher (SUPER + SPACE)\n"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
DESKTOP_DIR="$HOME/.local/share/applications/"
|
DESKTOP_DIR="$HOME/.local/share/applications/"
|
||||||
|
|
||||||
if [ "$#" -ne 1 ]; then
|
if [ "$#" -eq 0 ]; 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=.*omarchy-launch-webapp.*' "$file"; then
|
||||||
@@ -14,23 +14,28 @@ if [ "$#" -ne 1 ]; then
|
|||||||
if ((${#WEB_APPS[@]})); then
|
if ((${#WEB_APPS[@]})); then
|
||||||
IFS=$'\n' SORTED_WEB_APPS=($(sort <<<"${WEB_APPS[*]}"))
|
IFS=$'\n' SORTED_WEB_APPS=($(sort <<<"${WEB_APPS[*]}"))
|
||||||
unset IFS
|
unset IFS
|
||||||
APP_NAME=$(gum choose --header "Select web app to remove..." "${SORTED_WEB_APPS[@]}")
|
APP_NAMES_STRING=$(gum choose --no-limit --header "Select web app to remove..." --selected-prefix="✗ " "${SORTED_WEB_APPS[@]}")
|
||||||
|
# Convert newline-separated string to array
|
||||||
|
APP_NAMES=()
|
||||||
|
while IFS= read -r line; do
|
||||||
|
[[ -n "$line" ]] && APP_NAMES+=("$line")
|
||||||
|
done <<< "$APP_NAMES_STRING"
|
||||||
else
|
else
|
||||||
echo "No web apps to remove."
|
echo "No web apps to remove."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
APP_NAME="$1"
|
# Use array to preserve spaces in app names
|
||||||
|
APP_NAMES=("$@")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "$APP_NAME" ]]; then
|
if [[ ${#APP_NAMES[@]} -eq 0 ]]; then
|
||||||
echo "You must provide web app name."
|
echo "You must provide web app names."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm "$DESKTOP_DIR/$APP_NAME.desktop"
|
for APP_NAME in "${APP_NAMES[@]}"; do
|
||||||
rm "$ICON_DIR/$APP_NAME.png"
|
rm -f "$DESKTOP_DIR/$APP_NAME.desktop"
|
||||||
|
rm -f "$ICON_DIR/$APP_NAME.png"
|
||||||
if [ "$#" -ne 1 ]; then
|
echo "Removed $APP_NAME"
|
||||||
echo -e "Removed $APP_NAME\n"
|
done
|
||||||
fi
|
|
||||||
|
|||||||
7
boot.sh
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Set install mode to online since boot.sh is used for curl installations
|
||||||
|
export OMARCHY_ONLINE_INSTALL=true
|
||||||
|
|
||||||
ansi_art=' ▄▄▄
|
ansi_art=' ▄▄▄
|
||||||
▄█████▄ ▄███████████▄ ▄███████ ▄███████ ▄███████ ▄█ █▄ ▄█ █▄
|
▄█████▄ ▄███████████▄ ▄███████ ▄███████ ▄███████ ▄█ █▄ ▄█ █▄
|
||||||
███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███
|
███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███ ███
|
||||||
@@ -14,7 +17,7 @@ ansi_art=' ▄▄▄
|
|||||||
clear
|
clear
|
||||||
echo -e "\n$ansi_art\n"
|
echo -e "\n$ansi_art\n"
|
||||||
|
|
||||||
sudo pacman -Sy --noconfirm --needed git
|
sudo pacman -Syu --noconfirm --needed git
|
||||||
|
|
||||||
# Use custom repo if specified, otherwise default to basecamp/omarchy
|
# Use custom repo if specified, otherwise default to basecamp/omarchy
|
||||||
OMARCHY_REPO="${OMARCHY_REPO:-basecamp/omarchy}"
|
OMARCHY_REPO="${OMARCHY_REPO:-basecamp/omarchy}"
|
||||||
@@ -26,7 +29,7 @@ git clone "https://github.com/${OMARCHY_REPO}.git" ~/.local/share/omarchy >/dev/
|
|||||||
# Use custom branch if instructed, otherwise default to master
|
# Use custom branch if instructed, otherwise default to master
|
||||||
OMARCHY_REF="${OMARCHY_REF:-master}"
|
OMARCHY_REF="${OMARCHY_REF:-master}"
|
||||||
if [[ $OMARCHY_REF != "master" ]]; then
|
if [[ $OMARCHY_REF != "master" ]]; then
|
||||||
echo -e "\eUsing branch: $OMARCHY_REF"
|
echo -e "\e[32mUsing branch: $OMARCHY_REF\e[0m"
|
||||||
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}"
|
||||||
cd -
|
cd -
|
||||||
|
|||||||