mirror of
https://github.com/basecamp/omarchy.git
synced 2026-02-17 15:25:37 +00:00
Compare commits
225 Commits
v2.0.1
...
update-oma
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8c30708b40 | ||
|
|
f5ec131b47 | ||
|
|
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 |
23
.github/ISSUE_TEMPLATE/bug.yml
vendored
Normal file
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
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
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
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
|
||||||
@@ -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[]? | .availability == "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"
|
||||||
|
|||||||
@@ -8,5 +8,6 @@ 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/battery-monitor.sh
|
||||||
$OMARCHY_PATH/install/first-run/firewall.sh
|
$OMARCHY_PATH/install/first-run/firewall.sh
|
||||||
|
$OMARCHY_PATH/install/first-run/gnome-theme.sh
|
||||||
sudo rm -f /etc/sudoers.d/first-run
|
sudo rm -f /etc/sudoers.d/first-run
|
||||||
fi
|
fi
|
||||||
|
|||||||
9
bin/omarchy-cmd-missing
Executable file
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
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
|
||||||
|
SCOPE="$1"
|
||||||
|
|
||||||
|
# Selects audio inclusion or not
|
||||||
|
AUDIO=$([[ $2 == "audio" ]] && echo "--audio")
|
||||||
|
|
||||||
|
start_screenrecording() {
|
||||||
filename="$OUTPUT_DIR/screenrecording-$(date +'%Y-%m-%d_%H-%M-%S').mp4"
|
filename="$OUTPUT_DIR/screenrecording-$(date +'%Y-%m-%d_%H-%M-%S').mp4"
|
||||||
notify-send "Screen recording starting..." -t 1000
|
|
||||||
sleep 1
|
|
||||||
|
|
||||||
if lspci | grep -Eqi 'nvidia|intel.*graphics'; then
|
if lspci | grep -Eqi 'nvidia|intel.*graphics'; then
|
||||||
wf-recorder -f "$filename" -c libx264 -p crf=23 -p preset=medium -p movflags=+faststart "$@"
|
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,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
function exit_screensaver {
|
||||||
|
pkill -x tte 2>/dev/null
|
||||||
|
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
trap exit_screensaver SIGINT SIGTERM SIGHUP SIGQUIT
|
||||||
|
|
||||||
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 +15,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; 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
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ if [[ ! -d "$OUTPUT_DIR" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
pkill slurp || hyprshot -m ${1:-region} --raw |
|
pkill slurp || hyprshot -m ${1:-region} --raw --freeze |
|
||||||
satty --filename - \
|
satty --filename - \
|
||||||
--output-filename "$OUTPUT_DIR/screenshot-$(date +'%Y-%m-%d_%H-%M-%S').png" \
|
--output-filename "$OUTPUT_DIR/screenshot-$(date +'%Y-%m-%d_%H-%M-%S').png" \
|
||||||
--early-exit \
|
--early-exit \
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
28
bin/omarchy-drive-info
Executable file
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
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
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,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)
|
||||||
@@ -120,4 +131,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,9 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# FIXME: Should not use AUR dependencies when we can avoid it
|
echo "Installing all dependencies..."
|
||||||
echo "Installing all dependencies [from AUR]..."
|
omarchy-pkg-add dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
||||||
yay -S --noconfirm --needed \
|
|
||||||
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,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo "Adding multilib repository for 32-bit compatibility"
|
echo "Adding multilib repository for 32-bit compatibility"
|
||||||
sudo sed -i '/^\s*#\[multilib\]/,/^$/{s/^\s*#//}' /etc/pacman.conf
|
sudo sed -i '/^#\s*\[multilib\]/,/^#\s*Include/ 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 &
|
||||||
|
|||||||
4
bin/omarchy-launch-floating-terminal-with-presentation
Executable file
4
bin/omarchy-launch-floating-terminal-with-presentation
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
cmd="$*"
|
||||||
|
setsid alacritty --class Omarchy -e bash -c "omarchy-show-logo; $cmd; omarchy-show-done"
|
||||||
103
bin/omarchy-menu
103
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 [[ "$DIRECT_ACCESS" == "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"
|
||||||
@@ -26,7 +41,7 @@ terminal() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
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() {
|
edit_in_nvim() {
|
||||||
@@ -35,23 +50,23 @@ edit_in_nvim() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
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'"
|
||||||
}
|
}
|
||||||
|
|
||||||
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() {
|
||||||
@@ -80,7 +95,7 @@ show_style_menu() {
|
|||||||
show_theme_menu() {
|
show_theme_menu() {
|
||||||
theme=$(menu "Theme" "$(omarchy-theme-list)" "" "$(omarchy-theme-current)")
|
theme=$(menu "Theme" "$(omarchy-theme-list)" "" "$(omarchy-theme-current)")
|
||||||
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
||||||
show_main_menu
|
back_to show_style_menu
|
||||||
else
|
else
|
||||||
omarchy-theme-set "$theme"
|
omarchy-theme-set "$theme"
|
||||||
fi
|
fi
|
||||||
@@ -89,7 +104,7 @@ show_theme_menu() {
|
|||||||
show_font_menu() {
|
show_font_menu() {
|
||||||
theme=$(menu "Font" "$(omarchy-font-list)" "-w 350" "$(omarchy-font-current)")
|
theme=$(menu "Font" "$(omarchy-font-list)" "-w 350" "$(omarchy-font-current)")
|
||||||
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
||||||
show_main_menu
|
back_to show_style_menu
|
||||||
else
|
else
|
||||||
omarchy-font-set "$theme"
|
omarchy-font-set "$theme"
|
||||||
fi
|
fi
|
||||||
@@ -114,8 +129,10 @@ 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
|
||||||
@@ -163,7 +180,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
|
||||||
@@ -200,32 +217,41 @@ 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") 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" ;;
|
||||||
*) 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 ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_ai_menu() {
|
show_install_ai_menu() {
|
||||||
case $(menu "Install" " Claude Code [AUR]\n Gemini\n LM Studio [AUR]\n Ollama\n Crush [AUR]\n opencode [AUR]") in
|
ollama_pkg=$(
|
||||||
*Claude*) aur_install "Claude Code" "claude-code" ;;
|
(command -v nvidia-smi &>/dev/null && echo ollama-cuda) ||
|
||||||
*Gemini*) install "Gemini" "gemini-cli" ;;
|
(command -v rocminfo &>/dev/null && echo ollama-rocm) ||
|
||||||
*Studio*) aur_install "LM Studio" "lmstudio" ;;
|
echo ollama
|
||||||
*Ollama*) install "Ollama" "ollama" ;;
|
)
|
||||||
*Crush*) aur_install "Crush" "crush-bin" ;;
|
|
||||||
*opencode*) aur_install "opencode" "opencode-bin" ;;
|
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" ;;
|
||||||
|
*OpenAI*) aur_install "OpenAI Codex" "openai-codex-bin" ;;
|
||||||
|
*Gemini*) aur_install "Gemini" "gemini-cli" ;;
|
||||||
|
*Studio*) install "LM Studio" "lmstudio" ;;
|
||||||
|
*Ollama*) install "Ollama" $ollama_pkg ;;
|
||||||
|
*Crush*) install "Crush" "crush-bin" ;;
|
||||||
|
*opencode*) install "opencode" "opencode" ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -234,7 +260,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 +285,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 +298,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,12 +342,14 @@ 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 Config\n Themes\n Process\n Hardware\n Password\n Timezone") in
|
||||||
*Omarchy*) present_terminal omarchy-update ;;
|
*Omarchy*) present_terminal omarchy-update ;;
|
||||||
*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
|
||||||
}
|
}
|
||||||
@@ -332,7 +361,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 +375,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,7 +403,7 @@ 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
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -377,15 +422,17 @@ go_to_menu() {
|
|||||||
*screenrecord*) show_screenrecord_menu ;;
|
*screenrecord*) show_screenrecord_menu ;;
|
||||||
*toggle*) show_toggle_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*) alacritty --class Omarchy -o font.size=9 -e bash -c 'fastfetch; read -n 1 -s' ;;
|
||||||
*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
|
||||||
|
|||||||
9
bin/omarchy-pkg-add
Executable file
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,7 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'yay -Sii {1}'
|
--preview 'yay -Sii {1}'
|
||||||
@@ -18,7 +16,7 @@ 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
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
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
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
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
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
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
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
4
bin/omarchy-restart-bluetooth
Executable file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
rfkill unblock bluetooth
|
||||||
|
rfkill list bluetooth
|
||||||
4
bin/omarchy-restart-wifi
Executable file
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
|
||||||
|
|||||||
@@ -7,4 +7,4 @@ omarchy-update-git
|
|||||||
omarchy-migrate
|
omarchy-migrate
|
||||||
omarchy-update-system-pkgs
|
omarchy-update-system-pkgs
|
||||||
omarchy-update-restart
|
omarchy-update-restart
|
||||||
omarchy-restart-waybar # removes update-available icon
|
omarchy-update-available-reset
|
||||||
|
|||||||
@@ -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
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
|
||||||
@@ -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)
|
||||||
|
|||||||
3
bin/omarchy-version-branch
Executable file
3
bin/omarchy-version-branch
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo $(git -C "$OMARCHY_PATH" rev-parse --abbrev-ref HEAD)
|
||||||
2
boot.sh
2
boot.sh
@@ -14,7 +14,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}"
|
||||||
|
|||||||
@@ -13,7 +13,6 @@ size = 9
|
|||||||
padding.x = 14
|
padding.x = 14
|
||||||
padding.y = 14
|
padding.y = 14
|
||||||
decorations = "None"
|
decorations = "None"
|
||||||
opacity = 0.98
|
|
||||||
|
|
||||||
[keyboard]
|
[keyboard]
|
||||||
bindings = [
|
bindings = [
|
||||||
|
|||||||
@@ -63,41 +63,20 @@
|
|||||||
"format": "\u001b[90m┌──────────────────────Software──────────────────────┐"
|
"format": "\u001b[90m┌──────────────────────Software──────────────────────┐"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "os",
|
"type": "command",
|
||||||
"key": " OS",
|
"key": "\ue900 OS",
|
||||||
"keyColor": "yellow"
|
"keyColor": "blue",
|
||||||
|
"text": "version=$(omarchy-version); echo \"Omarchy $version\""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "command",
|
||||||
|
"key": "│ ├",
|
||||||
|
"keyColor": "blue",
|
||||||
|
"text": "branch=$(omarchy-version-branch); echo \"$branch\""
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "kernel",
|
"type": "kernel",
|
||||||
"key": "│ ├",
|
"key": "│ ├",
|
||||||
"keyColor": "yellow"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "packages",
|
|
||||||
"key": "│ ├",
|
|
||||||
"keyColor": "yellow"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "shell",
|
|
||||||
"key": "└ └",
|
|
||||||
"keyColor": "yellow"
|
|
||||||
},
|
|
||||||
"break",
|
|
||||||
{
|
|
||||||
"type": "command",
|
|
||||||
"key": "Ø Omarchy",
|
|
||||||
"keyColor": "blue",
|
|
||||||
"text": "version=$(git -C ~/.local/share/omarchy describe --tags --abbrev=0 2>/dev/null); echo \"$version\""
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "command",
|
|
||||||
"key": "│ ├",
|
|
||||||
"keyColor": "blue",
|
|
||||||
"text": "theme=$(omarchy-theme-current); echo -e \"$theme \\e[38m●\\e[37m●\\e[36m●\\e[35m●\\e[34m●\\e[33m●\\e[32m●\\e[31m●\""
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "de",
|
|
||||||
"key": " DE",
|
|
||||||
"keyColor": "blue"
|
"keyColor": "blue"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -105,29 +84,35 @@
|
|||||||
"key": "│ ├",
|
"key": "│ ├",
|
||||||
"keyColor": "blue"
|
"keyColor": "blue"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"type": "de",
|
||||||
|
"key": " DE",
|
||||||
|
"keyColor": "blue"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "terminal",
|
||||||
|
"key": "│ ├",
|
||||||
|
"keyColor": "blue"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "packages",
|
||||||
|
"key": "│ ├",
|
||||||
|
"keyColor": "blue"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type": "wmtheme",
|
"type": "wmtheme",
|
||||||
"key": "│ ├",
|
"key": "│ ├",
|
||||||
"keyColor": "blue"
|
"keyColor": "blue"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "icons",
|
"type": "command",
|
||||||
"key": "│ ├",
|
"key": "│ ├",
|
||||||
"keyColor": "blue"
|
"keyColor": "blue",
|
||||||
},
|
"text": "theme=$(omarchy-theme-current); echo -e \"$theme \\e[38m●\\e[37m●\\e[36m●\\e[35m●\\e[34m●\\e[33m●\\e[32m●\\e[31m●\""
|
||||||
{
|
|
||||||
"type": "cursor",
|
|
||||||
"key": "│ ├",
|
|
||||||
"keyColor": "blue"
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "terminalfont",
|
"type": "terminalfont",
|
||||||
"key": "│ ├",
|
"key": "└ └",
|
||||||
"keyColor": "blue"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "terminal",
|
|
||||||
"key": "└ └",
|
|
||||||
"keyColor": "blue"
|
"keyColor": "blue"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -141,13 +126,13 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "command",
|
"type": "command",
|
||||||
"key": " OS Age ",
|
"key": " OS Age",
|
||||||
"keyColor": "magenta",
|
"keyColor": "magenta",
|
||||||
"text": "birth_install=$(stat -c %W /); current=$(date +%s); time_progression=$((current - birth_install)); days_difference=$((time_progression / 86400)); echo $days_difference days"
|
"text": "birth_install=$(stat -c %W /); current=$(date +%s); time_progression=$((current - birth_install)); days_difference=$((time_progression / 86400)); echo $days_difference days"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "uptime",
|
"type": "uptime",
|
||||||
"key": " Uptime ",
|
"key": " Uptime",
|
||||||
"keyColor": "magenta"
|
"keyColor": "magenta"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
$terminal = uwsm app -- alacritty
|
$terminal = uwsm app -- alacritty
|
||||||
$browser = omarchy-launch-browser
|
$browser = omarchy-launch-browser
|
||||||
|
|
||||||
bindd = SUPER, return, Terminal, exec, $terminal --working-directory $(omarchy-cmd-terminal-cwd)
|
bindd = SUPER, return, Terminal, exec, $terminal --working-directory="$(omarchy-cmd-terminal-cwd)"
|
||||||
bindd = SUPER, F, File manager, exec, uwsm app -- nautilus --new-window
|
bindd = SUPER, F, File manager, exec, uwsm app -- nautilus --new-window
|
||||||
bindd = SUPER, B, Browser, exec, $browser
|
bindd = SUPER, B, Browser, exec, $browser
|
||||||
bindd = SUPER, M, Music, exec, uwsm app -- spotify
|
bindd = SUPER, M, Music, exec, uwsm app -- spotify
|
||||||
@@ -25,5 +25,5 @@ bindd = SUPER, X, X, exec, omarchy-launch-webapp "https://x.com/"
|
|||||||
bindd = SUPER SHIFT, X, X Post, exec, omarchy-launch-webapp "https://x.com/compose/post"
|
bindd = SUPER SHIFT, X, X Post, exec, omarchy-launch-webapp "https://x.com/compose/post"
|
||||||
|
|
||||||
# Overwrite existing bindings, like putting Omarchy Menu on Super + Space
|
# Overwrite existing bindings, like putting Omarchy Menu on Super + Space
|
||||||
# unbind = SUPER, Space
|
# unbind = SUPER, SPACE
|
||||||
# bindd = SUPER, SPACE, Omarchy menu, exec, omarchy-menu
|
# bindd = SUPER, SPACE, Omarchy menu, exec, omarchy-menu
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ general {
|
|||||||
lock_cmd = omarchy-lock-screen # lock screen and 1password
|
lock_cmd = omarchy-lock-screen # lock screen and 1password
|
||||||
before_sleep_cmd = loginctl lock-session # lock before suspend.
|
before_sleep_cmd = loginctl lock-session # lock before suspend.
|
||||||
after_sleep_cmd = hyprctl dispatch dpms on # to avoid having to press a key twice to turn on the display.
|
after_sleep_cmd = hyprctl dispatch dpms on # to avoid having to press a key twice to turn on the display.
|
||||||
on_unlock_cmd = omarchy-restart-waybar # prevent stacking of waybar when waking
|
|
||||||
inhibit_sleep = 3 # wait until screen is locked
|
inhibit_sleep = 3 # wait until screen is locked
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,6 +9,9 @@ input {
|
|||||||
repeat_rate = 40
|
repeat_rate = 40
|
||||||
repeat_delay = 600
|
repeat_delay = 600
|
||||||
|
|
||||||
|
# Start with numlock on by default
|
||||||
|
numlock_by_default = true
|
||||||
|
|
||||||
# Increase sensitity for mouse/trackpack (default: 0)
|
# Increase sensitity for mouse/trackpack (default: 0)
|
||||||
# sensitivity = 0.35
|
# sensitivity = 0.35
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
"spacing": 0,
|
"spacing": 0,
|
||||||
"height": 26,
|
"height": 26,
|
||||||
"modules-left": ["custom/omarchy", "hyprland/workspaces"],
|
"modules-left": ["custom/omarchy", "hyprland/workspaces"],
|
||||||
"modules-center": ["clock", "custom/update"],
|
"modules-center": ["clock", "custom/update", "custom/screenrecording-indicator"],
|
||||||
"modules-right": [
|
"modules-right": [
|
||||||
"group/tray-expander",
|
"group/tray-expander",
|
||||||
"bluetooth",
|
"bluetooth",
|
||||||
@@ -46,8 +46,9 @@
|
|||||||
"custom/update": {
|
"custom/update": {
|
||||||
"format": "",
|
"format": "",
|
||||||
"exec": "omarchy-update-available",
|
"exec": "omarchy-update-available",
|
||||||
"on-click": "alacritty --class Omarchy --title Omarchy -e omarchy-update",
|
"on-click": "omarchy-launch-floating-terminal-with-presentation omarchy-update",
|
||||||
"tooltip-format": "Omarchy update available",
|
"tooltip-format": "Omarchy update available",
|
||||||
|
"signal": 7,
|
||||||
"interval": 3600
|
"interval": 3600
|
||||||
},
|
},
|
||||||
|
|
||||||
@@ -57,8 +58,8 @@
|
|||||||
"on-click": "alacritty -e btop"
|
"on-click": "alacritty -e btop"
|
||||||
},
|
},
|
||||||
"clock": {
|
"clock": {
|
||||||
"format": "{:%A %H:%M}",
|
"format": "{:L%A %H:%M}",
|
||||||
"format-alt": "{:%d %B W%V %Y}",
|
"format-alt": "{:L%d %B W%V %Y}",
|
||||||
"tooltip": false,
|
"tooltip": false,
|
||||||
"on-click-right": "omarchy-cmd-tzupdate"
|
"on-click-right": "omarchy-cmd-tzupdate"
|
||||||
},
|
},
|
||||||
@@ -88,6 +89,7 @@
|
|||||||
"tooltip-format-discharging": "{power:>1.0f}W↓ {capacity}%",
|
"tooltip-format-discharging": "{power:>1.0f}W↓ {capacity}%",
|
||||||
"tooltip-format-charging": "{power:>1.0f}W↑ {capacity}%",
|
"tooltip-format-charging": "{power:>1.0f}W↑ {capacity}%",
|
||||||
"interval": 5,
|
"interval": 5,
|
||||||
|
"on-click": "omarchy-menu power",
|
||||||
"states": {
|
"states": {
|
||||||
"warning": 20,
|
"warning": 20,
|
||||||
"critical": 10
|
"critical": 10
|
||||||
@@ -123,6 +125,12 @@
|
|||||||
"format": " ",
|
"format": " ",
|
||||||
"tooltip": false
|
"tooltip": false
|
||||||
},
|
},
|
||||||
|
"custom/screenrecording-indicator": {
|
||||||
|
"on-click": "omarchy-cmd-screenrecord",
|
||||||
|
"exec": "$OMARCHY_PATH/default/waybar/indicators/screen-recording.sh",
|
||||||
|
"signal": 8,
|
||||||
|
"return-type": "json"
|
||||||
|
},
|
||||||
"tray": {
|
"tray": {
|
||||||
"icon-size": 12,
|
"icon-size": 12,
|
||||||
"spacing": 12
|
"spacing": 12
|
||||||
|
|||||||
@@ -37,6 +37,7 @@
|
|||||||
#bluetooth,
|
#bluetooth,
|
||||||
#pulseaudio,
|
#pulseaudio,
|
||||||
#custom-omarchy,
|
#custom-omarchy,
|
||||||
|
#custom-screenrecording-indicator,
|
||||||
#custom-update {
|
#custom-update {
|
||||||
min-width: 12px;
|
min-width: 12px;
|
||||||
margin: 0 7.5px;
|
margin: 0 7.5px;
|
||||||
@@ -61,3 +62,13 @@ tooltip {
|
|||||||
.hidden {
|
.hidden {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#custom-screenrecording-indicator {
|
||||||
|
min-width: 12px;
|
||||||
|
margin-left: 8.75px;
|
||||||
|
font-size: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#custom-screenrecording-indicator.active {
|
||||||
|
color: #a55555;
|
||||||
|
}
|
||||||
|
|||||||
@@ -24,12 +24,12 @@ alias ...='cd ../..'
|
|||||||
alias ....='cd ../../..'
|
alias ....='cd ../../..'
|
||||||
|
|
||||||
# Tools
|
# Tools
|
||||||
alias g='git'
|
|
||||||
alias d='docker'
|
alias d='docker'
|
||||||
alias r='rails'
|
alias r='rails'
|
||||||
n() { if [ "$#" -eq 0 ]; then nvim .; else nvim "$@"; fi; }
|
n() { if [ "$#" -eq 0 ]; then nvim .; else nvim "$@"; fi; }
|
||||||
|
|
||||||
# Git
|
# Git
|
||||||
|
alias g='git'
|
||||||
alias gcm='git commit -m'
|
alias gcm='git commit -m'
|
||||||
alias gcam='git commit -a -m'
|
alias gcam='git commit -a -m'
|
||||||
alias gcad='git commit -a --amend'
|
alias gcad='git commit -a --amend'
|
||||||
|
|||||||
@@ -65,4 +65,3 @@ img2png() {
|
|||||||
-define png:exclude-chunk=all \
|
-define png:exclude-chunk=all \
|
||||||
"${1%.*}.png"
|
"${1%.*}.png"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,12 @@
|
|||||||
# App-specific tweaks
|
# App-specific tweaks
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/pip.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/1password.conf
|
||||||
|
source = ~/.local/share/omarchy/default/hypr/apps/bitwarden.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/browser.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/browser.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/hyprshot.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/hyprshot.conf
|
||||||
|
source = ~/.local/share/omarchy/default/hypr/apps/jetbrains.conf
|
||||||
|
source = ~/.local/share/omarchy/default/hypr/apps/pip.conf
|
||||||
|
source = ~/.local/share/omarchy/default/hypr/apps/qemu.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/retroarch.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/retroarch.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/steam.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/steam.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/system.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/system.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/walker.conf
|
source = ~/.local/share/omarchy/default/hypr/apps/walker.conf
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/1password.conf
|
|
||||||
source = ~/.local/share/omarchy/default/hypr/apps/jetbrains.conf
|
|
||||||
|
|||||||
1
default/hypr/apps/bitwarden.conf
Normal file
1
default/hypr/apps/bitwarden.conf
Normal file
@@ -0,0 +1 @@
|
|||||||
|
windowrule = noscreenshare, class:^(Bitwarden)$
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
# Browser types
|
# Browser types
|
||||||
windowrule = tag +chromium-based-browser, class:([cC]hrom(e|ium)|[bB]rave-browser|Microsoft-edge|Vivaldi-stable)
|
windowrule = tag +chromium-based-browser, class:([cC]hrom(e|ium)|[bB]rave-browser|Microsoft-edge|Vivaldi-stable)
|
||||||
windowrule = tag +firefox-based-browser, class:(Firefox|zen|librewolf)
|
windowrule = tag +firefox-based-browser, class:([fF]irefox|zen|librewolf)
|
||||||
|
|
||||||
# Force chromium-based browsers into a tile to deal with --app bug
|
# Force chromium-based browsers into a tile to deal with --app bug
|
||||||
windowrule = tile, tag:chromium-based-browser
|
windowrule = tile, tag:chromium-based-browser
|
||||||
@@ -10,4 +10,4 @@ windowrule = opacity 1 0.97, tag:chromium-based-browser
|
|||||||
windowrule = opacity 1 0.97, tag:firefox-based-browser
|
windowrule = opacity 1 0.97, tag:firefox-based-browser
|
||||||
|
|
||||||
# Some video sites should never have opacity applied to them
|
# Some video sites should never have opacity applied to them
|
||||||
windowrule = opacity 1.0 1.0, initialTitle:(youtube\.com_/|app\.zoom\.us_/wc/home)
|
windowrule = opacity 1.0 1.0, initialTitle:((?i)(?:[a-z0-9-]+\.)*youtube\.com_/|app\.zoom\.us_/wc/home)
|
||||||
|
|||||||
@@ -1,10 +1,6 @@
|
|||||||
# Fixing popup size issue
|
# Fixing popup size issue
|
||||||
windowrule = size 50% 50%, class:(.*jetbrains.*)$, title:^$,floating:1
|
windowrule = size 50% 50%, class:(.*jetbrains.*)$, title:^$,floating:1
|
||||||
|
|
||||||
# Fix tooltips (always have a title of `win.<id>`)
|
|
||||||
windowrule = noinitialfocus, class:^(.*jetbrains.*)$, title:^(win.*)$
|
|
||||||
windowrule = nofocus, class:^(.*jetbrains.*)$, title:^(win.*)$
|
|
||||||
|
|
||||||
# Fix tab dragging (always have a single space character as their title)
|
# Fix tab dragging (always have a single space character as their title)
|
||||||
windowrule = noinitialfocus, class:^(.*jetbrains.*)$, title:^\\s$
|
windowrule = noinitialfocus, class:^(.*jetbrains.*)$, title:^\\s$
|
||||||
windowrule = nofocus, class:^(.*jetbrains.*)$, title:^\\s$
|
windowrule = nofocus, class:^(.*jetbrains.*)$, title:^\\s$
|
||||||
|
|||||||
1
default/hypr/apps/qemu.conf
Normal file
1
default/hypr/apps/qemu.conf
Normal file
@@ -0,0 +1 @@
|
|||||||
|
windowrule = opacity 1 1, class:qemu
|
||||||
@@ -1,3 +1,4 @@
|
|||||||
windowrule = fullscreen, class:com.libretro.RetroArch
|
windowrule = fullscreen, class:com.libretro.RetroArch
|
||||||
windowrule = opacity 1 1, class:com.libretro.RetroArch
|
windowrule = opacity 1 1, class:com.libretro.RetroArch
|
||||||
|
windowrule = idleinhibit fullscreen, class:com.libretro.RetroArch
|
||||||
|
|
||||||
|
|||||||
@@ -4,3 +4,4 @@ windowrule = center, class:steam, title:Steam
|
|||||||
windowrule = opacity 1 1, class:steam
|
windowrule = opacity 1 1, class:steam
|
||||||
windowrule = size 1100 700, class:steam, title:Steam
|
windowrule = size 1100 700, class:steam, title:Steam
|
||||||
windowrule = size 460 800, class:steam, title:Friends List
|
windowrule = size 460 800, class:steam, title:Friends List
|
||||||
|
windowrule = idleinhibit fullscreen, class:steam
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ windowrule = center, tag:floating-window
|
|||||||
windowrule = size 800 600, tag:floating-window
|
windowrule = size 800 600, tag:floating-window
|
||||||
|
|
||||||
windowrule = tag +floating-window, class:(blueberry.py|Impala|Wiremix|org.gnome.NautilusPreviewer|com.gabm.satty|Omarchy|About|TUI.float)
|
windowrule = tag +floating-window, class:(blueberry.py|Impala|Wiremix|org.gnome.NautilusPreviewer|com.gabm.satty|Omarchy|About|TUI.float)
|
||||||
windowrule = tag +floating-window, class:(xdg-desktop-portal-gtk|sublime_text|DesktopEditors), title:^(Open.*Files?|Save.*Files?|Save.*As|All Files|Save)
|
windowrule = tag +floating-window, class:(xdg-desktop-portal-gtk|sublime_text|DesktopEditors|org.gnome.Nautilus), title:^(Open.*Files?|Open Folder|Save.*Files?|Save.*As|Save|All Files)
|
||||||
|
|
||||||
# Fullscreen screensaver
|
# Fullscreen screensaver
|
||||||
windowrule = fullscreen, class:Screensaver
|
windowrule = fullscreen, class:Screensaver
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ bindld = , XF86PowerOff, Power menu, exec, omarchy-menu system
|
|||||||
bindd = SUPER, K, Show key bindings, exec, omarchy-menu-keybindings
|
bindd = SUPER, K, Show key bindings, exec, omarchy-menu-keybindings
|
||||||
|
|
||||||
# Aesthetics
|
# Aesthetics
|
||||||
bindd = SUPER SHIFT, SPACE, Toggle top bar, exec, pkill -SIGUSR1 waybar
|
bindd = SUPER SHIFT, SPACE, Toggle top bar, exec, omarchy-toggle-waybar
|
||||||
bindd = SUPER CTRL, SPACE, Next background in theme, exec, omarchy-theme-bg-next
|
bindd = SUPER CTRL, SPACE, Next background in theme, exec, omarchy-theme-bg-next
|
||||||
bindd = SUPER SHIFT CTRL, SPACE, Pick new theme, exec, omarchy-menu theme
|
bindd = SUPER SHIFT CTRL, SPACE, Pick new theme, exec, omarchy-menu theme
|
||||||
|
|
||||||
@@ -33,8 +33,10 @@ bindd = SHIFT, PRINT, Screenshot of window, exec, omarchy-cmd-screenshot window
|
|||||||
bindd = CTRL, PRINT, Screenshot of display, exec, omarchy-cmd-screenshot output
|
bindd = CTRL, PRINT, Screenshot of display, exec, omarchy-cmd-screenshot output
|
||||||
|
|
||||||
# Screen recordings
|
# Screen recordings
|
||||||
bindd = ALT, PRINT, Screen record a region, exec, omarchy-cmd-screenrecord
|
bindd = ALT, PRINT, Screen record a region, exec, omarchy-cmd-screenrecord region
|
||||||
|
bindd = ALT SHIFT, PRINT, Screen record a region with audio, exec, omarchy-cmd-screenrecord region audio
|
||||||
bindd = CTRL ALT, PRINT, Screen record display, exec, omarchy-cmd-screenrecord output
|
bindd = CTRL ALT, PRINT, Screen record display, exec, omarchy-cmd-screenrecord output
|
||||||
|
bindd = CTRL ALT SHIFT, PRINT, Screen record display with audio, exec, omarchy-cmd-screenrecord output audio
|
||||||
|
|
||||||
# Color picker
|
# Color picker
|
||||||
bindd = SUPER, PRINT, Color picker, exec, pkill hyprpicker || hyprpicker -a
|
bindd = SUPER, PRINT, Color picker, exec, pkill hyprpicker || hyprpicker -a
|
||||||
|
|||||||
@@ -10,6 +10,11 @@ env = SDL_VIDEODRIVER,wayland
|
|||||||
env = MOZ_ENABLE_WAYLAND,1
|
env = MOZ_ENABLE_WAYLAND,1
|
||||||
env = ELECTRON_OZONE_PLATFORM_HINT,wayland
|
env = ELECTRON_OZONE_PLATFORM_HINT,wayland
|
||||||
env = OZONE_PLATFORM,wayland
|
env = OZONE_PLATFORM,wayland
|
||||||
|
env = XDG_SESSION_TYPE,wayland
|
||||||
|
|
||||||
|
# Allow better support for screen sharing (Google Meet, Discord, etc)
|
||||||
|
env = XDG_CURRENT_DESKTOP,Hyprland
|
||||||
|
env = XDG_SESSION_DESKTOP,Hyprland
|
||||||
|
|
||||||
xwayland {
|
xwayland {
|
||||||
force_zero_scaling = true
|
force_zero_scaling = true
|
||||||
|
|||||||
16
default/mako/core.ini
Normal file
16
default/mako/core.ini
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
anchor=top-right
|
||||||
|
default-timeout=5000
|
||||||
|
width=420
|
||||||
|
height=110
|
||||||
|
|
||||||
|
[app-name=Spotify]
|
||||||
|
invisible=1
|
||||||
|
|
||||||
|
[mode=do-not-disturb]
|
||||||
|
invisible=true
|
||||||
|
|
||||||
|
[mode=do-not-disturb app-name=notify-send]
|
||||||
|
invisible=false
|
||||||
|
|
||||||
|
[urgency=critical]
|
||||||
|
default-timeout=0
|
||||||
3
default/pacman/mirrorlist
Normal file
3
default/pacman/mirrorlist
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Server = https://mirror.omarchy.org/$repo/os/$arch
|
||||||
|
Server = https://mirror.rackspace.com/archlinux/$repo/os/$arch
|
||||||
|
Server = https://geo.mirror.pkgbuild.com/$repo/os/$arch
|
||||||
30
default/pacman/pacman.conf
Normal file
30
default/pacman/pacman.conf
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
# See the pacman.conf(5) manpage for option and repository directives
|
||||||
|
|
||||||
|
[options]
|
||||||
|
Color
|
||||||
|
ILoveCandy
|
||||||
|
VerbosePkgLists
|
||||||
|
HoldPkg = pacman glibc
|
||||||
|
Architecture = auto
|
||||||
|
CheckSpace
|
||||||
|
ParallelDownloads = 5
|
||||||
|
DownloadUser = alpm
|
||||||
|
|
||||||
|
# By default, pacman accepts packages signed by keys that its local keyring
|
||||||
|
# trusts (see pacman-key and its man page), as well as unsigned packages.
|
||||||
|
SigLevel = Required DatabaseOptional
|
||||||
|
LocalFileSigLevel = Optional
|
||||||
|
|
||||||
|
# pacman searches repositories in the order defined here
|
||||||
|
[core]
|
||||||
|
Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
[extra]
|
||||||
|
Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
# [multilib]
|
||||||
|
# Include = /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
[omarchy]
|
||||||
|
SigLevel = Optional TrustAll
|
||||||
|
Server = https://pkgs.omarchy.org/$arch
|
||||||
@@ -7,3 +7,5 @@ ModuleName=script
|
|||||||
ImageDir=/usr/share/plymouth/themes/omarchy
|
ImageDir=/usr/share/plymouth/themes/omarchy
|
||||||
ScriptFile=/usr/share/plymouth/themes/omarchy/omarchy.script
|
ScriptFile=/usr/share/plymouth/themes/omarchy/omarchy.script
|
||||||
ConsoleLogBackgroundColor=0x1a1b26
|
ConsoleLogBackgroundColor=0x1a1b26
|
||||||
|
MonospaceFont=Cantarell 11
|
||||||
|
Font=Cantarell 11
|
||||||
|
|||||||
7
default/waybar/indicators/screen-recording.sh
Executable file
7
default/waybar/indicators/screen-recording.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if pgrep -x wl-screenrec >/dev/null || pgrep -x wf-recorder >/dev/null; then
|
||||||
|
echo '{"text": "", "tooltip": "Stop recording", "class": "active"}'
|
||||||
|
else
|
||||||
|
echo '{"text": ""}'
|
||||||
|
fi
|
||||||
34
install.sh
34
install.sh
@@ -3,21 +3,21 @@
|
|||||||
# Exit immediately if a command exits with a non-zero status
|
# Exit immediately if a command exits with a non-zero status
|
||||||
set -eE
|
set -eE
|
||||||
|
|
||||||
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
OMARCHY_PATH="$HOME/.local/share/omarchy"
|
||||||
OMARCHY_INSTALL=~/.local/share/omarchy/install
|
OMARCHY_INSTALL="$OMARCHY_PATH/install"
|
||||||
|
export PATH="$OMARCHY_PATH/bin:$PATH"
|
||||||
|
|
||||||
# Preparation
|
# Preparation
|
||||||
source $OMARCHY_INSTALL/preflight/show-env.sh
|
source $OMARCHY_INSTALL/preflight/show-env.sh
|
||||||
source $OMARCHY_INSTALL/preflight/trap-errors.sh
|
source $OMARCHY_INSTALL/preflight/trap-errors.sh
|
||||||
source $OMARCHY_INSTALL/preflight/guard.sh
|
source $OMARCHY_INSTALL/preflight/guard.sh
|
||||||
source $OMARCHY_INSTALL/preflight/chroot.sh
|
source $OMARCHY_INSTALL/preflight/chroot.sh
|
||||||
source $OMARCHY_INSTALL/preflight/repositories.sh
|
source $OMARCHY_INSTALL/preflight/pacman.sh
|
||||||
source $OMARCHY_INSTALL/preflight/migrations.sh
|
source $OMARCHY_INSTALL/preflight/migrations.sh
|
||||||
source $OMARCHY_INSTALL/preflight/first-run-mode.sh
|
source $OMARCHY_INSTALL/preflight/first-run-mode.sh
|
||||||
|
|
||||||
# Packaging
|
# Packaging
|
||||||
source $OMARCHY_INSTALL/packages.sh
|
source $OMARCHY_INSTALL/packages.sh
|
||||||
source $OMARCHY_INSTALL/packaging/asdcontrol.sh
|
|
||||||
source $OMARCHY_INSTALL/packaging/fonts.sh
|
source $OMARCHY_INSTALL/packaging/fonts.sh
|
||||||
source $OMARCHY_INSTALL/packaging/lazyvim.sh
|
source $OMARCHY_INSTALL/packaging/lazyvim.sh
|
||||||
source $OMARCHY_INSTALL/packaging/webapps.sh
|
source $OMARCHY_INSTALL/packaging/webapps.sh
|
||||||
@@ -38,35 +38,23 @@ source $OMARCHY_INSTALL/config/xcompose.sh
|
|||||||
source $OMARCHY_INSTALL/config/mise-ruby.sh
|
source $OMARCHY_INSTALL/config/mise-ruby.sh
|
||||||
source $OMARCHY_INSTALL/config/docker.sh
|
source $OMARCHY_INSTALL/config/docker.sh
|
||||||
source $OMARCHY_INSTALL/config/mimetypes.sh
|
source $OMARCHY_INSTALL/config/mimetypes.sh
|
||||||
|
source $OMARCHY_INSTALL/config/localdb.sh
|
||||||
|
source $OMARCHY_INSTALL/config/sudoless-asdcontrol.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/network.sh
|
source $OMARCHY_INSTALL/config/hardware/network.sh
|
||||||
|
source $OMARCHY_INSTALL/config/hardware/set-wireless-regdom.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/fix-fkeys.sh
|
source $OMARCHY_INSTALL/config/hardware/fix-fkeys.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/bluetooth.sh
|
source $OMARCHY_INSTALL/config/hardware/bluetooth.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/printer.sh
|
source $OMARCHY_INSTALL/config/hardware/printer.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/usb-autosuspend.sh
|
source $OMARCHY_INSTALL/config/hardware/usb-autosuspend.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/ignore-power-button.sh
|
source $OMARCHY_INSTALL/config/hardware/ignore-power-button.sh
|
||||||
source $OMARCHY_INSTALL/config/hardware/nvidia.sh
|
source $OMARCHY_INSTALL/config/hardware/nvidia.sh
|
||||||
|
source $OMARCHY_INSTALL/config/hardware/intel.sh
|
||||||
|
source $OMARCHY_INSTALL/config/hardware/fix-f13-amd-audio-input.sh
|
||||||
|
|
||||||
# Login
|
# Login
|
||||||
source $OMARCHY_INSTALL/login/plymouth.sh
|
source $OMARCHY_INSTALL/login/plymouth.sh
|
||||||
source $OMARCHY_INSTALL/login/limine-snapper.sh
|
source $OMARCHY_INSTALL/login/limine-snapper.sh
|
||||||
source $OMARCHY_INSTALL/login/alt-bootloaders.sh
|
source $OMARCHY_INSTALL/login/alt-bootloaders.sh
|
||||||
|
|
||||||
# Updates
|
# Finishing
|
||||||
sudo updatedb
|
source $OMARCHY_INSTALL/reboot.sh
|
||||||
|
|
||||||
# Update system packages
|
|
||||||
sudo pacman -Syu --noconfirm
|
|
||||||
|
|
||||||
# Reboot
|
|
||||||
clear
|
|
||||||
tte -i ~/.local/share/omarchy/logo.txt --frame-rate 920 laseretch
|
|
||||||
echo
|
|
||||||
echo "You're done! So we're ready to reboot now..." | tte --frame-rate 640 wipe
|
|
||||||
|
|
||||||
if sudo test -f /etc/sudoers.d/99-omarchy-installer; then
|
|
||||||
sudo rm -f /etc/sudoers.d/99-omarchy-installer &>/dev/null
|
|
||||||
echo -e "\nRemember to remove USB installer!\n\n"
|
|
||||||
fi
|
|
||||||
|
|
||||||
sleep 5
|
|
||||||
reboot
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
# Copy over the keyboard layout that's been set in Arch during install to Hyprland
|
# Copy over the keyboard layout that's been set in Arch during install to Hyprland
|
||||||
conf="/etc/vconsole.conf"
|
conf="/etc/vconsole.conf"
|
||||||
hyprconf="$HOME/.config/hypr/hyprland.conf"
|
hyprconf="$HOME/.config/hypr/input.conf"
|
||||||
|
|
||||||
layout=$(grep '^XKBLAYOUT=' "$conf" | cut -d= -f2 | tr -d '"')
|
layout=$(grep '^XKBLAYOUT=' "$conf" | cut -d= -f2 | tr -d '"')
|
||||||
variant=$(grep '^XKBVARIANT=' "$conf" | cut -d= -f2 | tr -d '"')
|
variant=$(grep '^XKBVARIANT=' "$conf" | cut -d= -f2 | tr -d '"')
|
||||||
|
|||||||
@@ -1,5 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Ensure git settings live under ~/.config
|
||||||
|
mkdir -p ~/.config/git
|
||||||
|
touch ~/.config/git/config
|
||||||
|
|
||||||
# Set common git aliases
|
# Set common git aliases
|
||||||
git config --global alias.co checkout
|
git config --global alias.co checkout
|
||||||
git config --global alias.br branch
|
git config --global alias.br branch
|
||||||
|
|||||||
7
install/config/hardware/fix-f13-amd-audio-input.sh
Executable file
7
install/config/hardware/fix-f13-amd-audio-input.sh
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
AMD_AUDIO_CARD=$(pactl list cards | grep -B20 "Family 17h/19h" | grep "Name: " | awk '{print $2}')
|
||||||
|
|
||||||
|
if [[ -n $AMD_AUDIO_CARD ]]; then
|
||||||
|
pactl set-card-profile "$AMD_AUDIO_CARD" "HiFi (Mic1, Mic2, Speaker)" 2>/dev/null || true
|
||||||
|
fi
|
||||||
14
install/config/hardware/intel.sh
Executable file
14
install/config/hardware/intel.sh
Executable file
@@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# This installs hardware video acceleration for Intel GPUs
|
||||||
|
# Check if we have an Intel GPU at all
|
||||||
|
if INTEL_GPU=$(lspci | grep -iE 'vga|3d|display' | grep -i 'intel'); then
|
||||||
|
# HD Graphics and newer uses intel-media-driver
|
||||||
|
if [[ "${INTEL_GPU,,}" =~ "hd graphics"|"xe"|"iris" ]]; then
|
||||||
|
sudo pacman -S --needed --noconfirm intel-media-driver
|
||||||
|
elif [[ "${INTEL_GPU,,}" =~ "gma" ]]; then
|
||||||
|
# Older generations from 2008 to ~2014-2017 use libva-intel-driver
|
||||||
|
sudo pacman -S --needed --noconfirm libva-intel-driver
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
@@ -1,11 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Install iwd explicitly if it wasn't included in archinstall
|
# Ensure iwd service will be started
|
||||||
# This can happen if archinstall used ethernet
|
sudo systemctl enable iwd.service
|
||||||
if ! command -v iwctl &>/dev/null; then
|
|
||||||
sudo pacman -S --noconfirm --needed iwd
|
|
||||||
chrootable_systemctl_enable iwd.service
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Prevent systemd-networkd-wait-online timeout on boot
|
# Prevent systemd-networkd-wait-online timeout on boot
|
||||||
sudo systemctl disable systemd-networkd-wait-online.service
|
sudo systemctl disable systemd-networkd-wait-online.service
|
||||||
|
|||||||
@@ -32,11 +32,11 @@ if [ -n "$(lspci | grep -i 'nvidia')" ]; then
|
|||||||
|
|
||||||
# Enable multilib repository for 32-bit libraries
|
# Enable multilib repository for 32-bit libraries
|
||||||
if ! grep -q "^\[multilib\]" /etc/pacman.conf; then
|
if ! grep -q "^\[multilib\]" /etc/pacman.conf; then
|
||||||
sudo sed -i '/^#\[multilib\]/,/^#Include/ s/^#//' /etc/pacman.conf
|
sudo sed -i '/^#\s*\[multilib\]/,/^#\s*Include/ s/^#\s*//' /etc/pacman.conf
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# force package database refresh
|
# force package database refresh
|
||||||
sudo pacman -Syy
|
sudo pacman -Syu --noconfirm
|
||||||
|
|
||||||
# Install packages
|
# Install packages
|
||||||
PACKAGES_TO_INSTALL=(
|
PACKAGES_TO_INSTALL=(
|
||||||
|
|||||||
@@ -7,6 +7,9 @@ sudo mkdir -p /etc/systemd/resolved.conf.d
|
|||||||
echo -e "[Resolve]\nMulticastDNS=no" | sudo tee /etc/systemd/resolved.conf.d/10-disable-multicast.conf
|
echo -e "[Resolve]\nMulticastDNS=no" | sudo tee /etc/systemd/resolved.conf.d/10-disable-multicast.conf
|
||||||
chrootable_systemctl_enable avahi-daemon.service
|
chrootable_systemctl_enable avahi-daemon.service
|
||||||
|
|
||||||
|
# Enable mDNS resolution for .local domains
|
||||||
|
sudo sed -i 's/^hosts:.*/hosts: mymachines mdns_minimal [NOTFOUND=return] resolve [!UNAVAIL=return] files myhostname dns/' /etc/nsswitch.conf
|
||||||
|
|
||||||
# Enable automatically adding remote printers
|
# Enable automatically adding remote printers
|
||||||
if ! grep -q '^CreateRemotePrinters Yes' /etc/cups/cups-browsed.conf; then
|
if ! grep -q '^CreateRemotePrinters Yes' /etc/cups/cups-browsed.conf; then
|
||||||
echo 'CreateRemotePrinters Yes' | sudo tee -a /etc/cups/cups-browsed.conf
|
echo 'CreateRemotePrinters Yes' | sudo tee -a /etc/cups/cups-browsed.conf
|
||||||
|
|||||||
36
install/config/hardware/set-wireless-regdom.sh
Executable file
36
install/config/hardware/set-wireless-regdom.sh
Executable file
@@ -0,0 +1,36 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# First check that wireless-regdb is there
|
||||||
|
if [ -f "/etc/conf.d/wireless-regdom" ]; then
|
||||||
|
unset WIRELESS_REGDOM
|
||||||
|
. /etc/conf.d/wireless-regdom
|
||||||
|
fi
|
||||||
|
|
||||||
|
# If the region is already set, we're done
|
||||||
|
if [ ! -n "${WIRELESS_REGDOM}" ]; then
|
||||||
|
# Get the current timezone
|
||||||
|
if [ -e "/etc/localtime" ]; then
|
||||||
|
TIMEZONE=$(readlink -f /etc/localtime)
|
||||||
|
TIMEZONE=${TIMEZONE#/usr/share/zoneinfo/}
|
||||||
|
|
||||||
|
# Some timezones are formatted with the two letter country code at the start
|
||||||
|
COUNTRY="${TIMEZONE%%/*}"
|
||||||
|
|
||||||
|
# If we don't have a two letter country, get it from the timezone table
|
||||||
|
if [[ ! "$COUNTRY" =~ ^[A-Z]{2}$ ]] && [ -f "/usr/share/zoneinfo/zone.tab" ]; then
|
||||||
|
COUNTRY=$(awk -v tz="$TIMEZONE" '$3 == tz {print $1; exit}' /usr/share/zoneinfo/zone.tab)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if we have a two letter country code
|
||||||
|
if [[ "$COUNTRY" =~ ^[A-Z]{2}$ ]]; then
|
||||||
|
# Append it to the wireless-regdom conf file that is used at boot
|
||||||
|
echo "WIRELESS_REGDOM=\"$COUNTRY\"" | sudo tee -a /etc/conf.d/wireless-regdom > /dev/null
|
||||||
|
|
||||||
|
# Also set it one off now
|
||||||
|
if command -v iw &> /dev/null; then
|
||||||
|
sudo iw reg set ${COUNTRY}
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
2
install/config/localdb.sh
Executable file
2
install/config/localdb.sh
Executable file
@@ -0,0 +1,2 @@
|
|||||||
|
# Update localdb so that locate will find everything installed
|
||||||
|
sudo updatedb
|
||||||
5
install/config/sudoless-asdcontrol.sh
Executable file
5
install/config/sudoless-asdcontrol.sh
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Setup sudo-less controls for controlling brightness on Apple Displays
|
||||||
|
echo "$USER ALL=(ALL) NOPASSWD: /usr/local/bin/asdcontrol" | sudo tee /etc/sudoers.d/asdcontrol
|
||||||
|
sudo chmod 440 /etc/sudoers.d/asdcontrol
|
||||||
@@ -1,8 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
gsettings set org.gnome.desktop.interface gtk-theme "Adwaita-dark"
|
# Set links for Nautilius action icons
|
||||||
gsettings set org.gnome.desktop.interface color-scheme "prefer-dark"
|
sudo ln -snf /usr/share/icons/Adwaita/symbolic/actions/go-previous-symbolic.svg /usr/share/icons/Yaru/scalable/actions/go-previous-symbolic.svg
|
||||||
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
sudo ln -snf /usr/share/icons/Adwaita/symbolic/actions/go-next-symbolic.svg /usr/share/icons/Yaru/scalable/actions/go-next-symbolic.svg
|
||||||
|
sudo gtk-update-icon-cache /usr/share/icons/Yaru
|
||||||
|
|
||||||
# Setup theme links
|
# Setup theme links
|
||||||
mkdir -p ~/.config/omarchy/themes
|
mkdir -p ~/.config/omarchy/themes
|
||||||
|
|||||||
@@ -17,6 +17,9 @@ sudo ufw allow in proto udp from 172.16.0.0/12 to 172.17.0.1 port 53 comment 'al
|
|||||||
# Turn on the firewall
|
# Turn on the firewall
|
||||||
sudo ufw --force enable
|
sudo ufw --force enable
|
||||||
|
|
||||||
|
# Enable UFW systemd service to start on boot
|
||||||
|
sudo systemctl enable ufw
|
||||||
|
|
||||||
# Turn on Docker protections
|
# Turn on Docker protections
|
||||||
sudo ufw-docker install
|
sudo ufw-docker install
|
||||||
sudo ufw reload
|
sudo ufw reload
|
||||||
|
|||||||
5
install/first-run/gnome-theme.sh
Executable file
5
install/first-run/gnome-theme.sh
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
gsettings set org.gnome.desktop.interface gtk-theme "Adwaita-dark"
|
||||||
|
gsettings set org.gnome.desktop.interface color-scheme "prefer-dark"
|
||||||
|
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
||||||
0
install/packages.ignored
Normal file
0
install/packages.ignored
Normal file
0
install/packages.pinned
Normal file
0
install/packages.pinned
Normal file
@@ -1,6 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
sudo pacman -S --noconfirm --needed \
|
sudo pacman -S --noconfirm --needed \
|
||||||
1password-beta \
|
1password-beta \
|
||||||
1password-cli \
|
1password-cli \
|
||||||
|
asdcontrol-git \
|
||||||
alacritty \
|
alacritty \
|
||||||
avahi \
|
avahi \
|
||||||
bash-completion \
|
bash-completion \
|
||||||
@@ -26,6 +29,7 @@ sudo pacman -S --noconfirm --needed \
|
|||||||
fcitx5-qt \
|
fcitx5-qt \
|
||||||
fd \
|
fd \
|
||||||
ffmpegthumbnailer \
|
ffmpegthumbnailer \
|
||||||
|
fontconfig \
|
||||||
fzf \
|
fzf \
|
||||||
gcc14 \
|
gcc14 \
|
||||||
github-cli \
|
github-cli \
|
||||||
@@ -34,6 +38,7 @@ sudo pacman -S --noconfirm --needed \
|
|||||||
gnome-themes-extra \
|
gnome-themes-extra \
|
||||||
gum \
|
gum \
|
||||||
gvfs-mtp \
|
gvfs-mtp \
|
||||||
|
gvfs-smb \
|
||||||
hypridle \
|
hypridle \
|
||||||
hyprland \
|
hyprland \
|
||||||
hyprland-qtutils \
|
hyprland-qtutils \
|
||||||
@@ -45,6 +50,7 @@ sudo pacman -S --noconfirm --needed \
|
|||||||
impala \
|
impala \
|
||||||
imv \
|
imv \
|
||||||
inetutils \
|
inetutils \
|
||||||
|
iwd \
|
||||||
jq \
|
jq \
|
||||||
kdenlive \
|
kdenlive \
|
||||||
kvantum-qt5 \
|
kvantum-qt5 \
|
||||||
@@ -82,6 +88,7 @@ sudo pacman -S --noconfirm --needed \
|
|||||||
python-gobject \
|
python-gobject \
|
||||||
python-poetry-core \
|
python-poetry-core \
|
||||||
python-terminaltexteffects \
|
python-terminaltexteffects \
|
||||||
|
qt5-wayland \
|
||||||
ripgrep \
|
ripgrep \
|
||||||
satty \
|
satty \
|
||||||
signal-desktop \
|
signal-desktop \
|
||||||
@@ -95,9 +102,8 @@ sudo pacman -S --noconfirm --needed \
|
|||||||
tldr \
|
tldr \
|
||||||
tree-sitter-cli \
|
tree-sitter-cli \
|
||||||
ttf-cascadia-mono-nerd \
|
ttf-cascadia-mono-nerd \
|
||||||
ttf-font-awesome \
|
|
||||||
ttf-ia-writer \
|
ttf-ia-writer \
|
||||||
ttf-jetbrains-mono \
|
ttf-jetbrains-mono-nerd \
|
||||||
typora \
|
typora \
|
||||||
tzupdate \
|
tzupdate \
|
||||||
ufw \
|
ufw \
|
||||||
@@ -108,11 +114,13 @@ sudo pacman -S --noconfirm --needed \
|
|||||||
waybar \
|
waybar \
|
||||||
wf-recorder \
|
wf-recorder \
|
||||||
whois \
|
whois \
|
||||||
|
wireless-regdb \
|
||||||
wiremix \
|
wiremix \
|
||||||
wireplumber \
|
wireplumber \
|
||||||
wl-clip-persist \
|
wl-clip-persist \
|
||||||
wl-clipboard \
|
wl-clipboard \
|
||||||
wl-screenrec \
|
wl-screenrec \
|
||||||
|
woff2-font-awesome \
|
||||||
xdg-desktop-portal-gtk \
|
xdg-desktop-portal-gtk \
|
||||||
xdg-desktop-portal-hyprland \
|
xdg-desktop-portal-hyprland \
|
||||||
xmlstarlet \
|
xmlstarlet \
|
||||||
|
|||||||
@@ -1,15 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Install asdcontrol for controlling brightness on Apple Displays
|
|
||||||
if ! command -v asdcontrol &>/dev/null; then
|
|
||||||
git clone https://github.com/nikosdion/asdcontrol.git /tmp/asdcontrol
|
|
||||||
cd /tmp/asdcontrol
|
|
||||||
make
|
|
||||||
sudo make install
|
|
||||||
cd -
|
|
||||||
rm -rf /tmp/asdcontrol
|
|
||||||
|
|
||||||
# Setup sudo-less controls
|
|
||||||
echo "$USER ALL=(ALL) NOPASSWD: /usr/local/bin/asdcontrol" | sudo tee /etc/sudoers.d/asdcontrol
|
|
||||||
sudo chmod 440 /etc/sudoers.d/asdcontrol
|
|
||||||
fi
|
|
||||||
13
install/packaging/pins.sh
Executable file
13
install/packaging/pins.sh
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# We pin explicit packages that are bad upstream here
|
||||||
|
pinned_packages=$(omarchy-pkg-pinned)
|
||||||
|
|
||||||
|
if [[ -n $pinned_packages ]]; then
|
||||||
|
echo -e "\e[32m\nInstall pinned system packages\e[0m"
|
||||||
|
|
||||||
|
for pinned in $pinned_packages; do
|
||||||
|
echo "sudo pacman -U --noconfirm $pinned"
|
||||||
|
sudo pacman -U --noconfirm $pinned
|
||||||
|
done
|
||||||
|
fi
|
||||||
11
install/preflight/pacman.sh
Executable file
11
install/preflight/pacman.sh
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install build tools
|
||||||
|
sudo pacman -S --needed --noconfirm base-devel
|
||||||
|
|
||||||
|
# Configure pacman
|
||||||
|
sudo cp -f ~/.local/share/omarchy/default/pacman/pacman.conf /etc/pacman.conf
|
||||||
|
sudo cp -f ~/.local/share/omarchy/default/pacman/mirrorlist /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
# Refresh all repos
|
||||||
|
sudo pacman -Syu --noconfirm
|
||||||
@@ -1,45 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# Install build tools
|
|
||||||
sudo pacman -Sy --needed --noconfirm base-devel
|
|
||||||
|
|
||||||
# Add fun and color and verbosity to the pacman installer
|
|
||||||
if ! grep -q "ILoveCandy" /etc/pacman.conf; then
|
|
||||||
sudo sed -i '/^\[options\]/a Color\nILoveCandy\nVerbosePkgLists' /etc/pacman.conf
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Add the Omarchy repository as first choice
|
|
||||||
if ! grep -q "omarchy" /etc/pacman.conf; then
|
|
||||||
sudo sed -i '/^\[core\]/i [omarchy]\nSigLevel = Optional TrustAll\nServer = https:\/\/pkgs.omarchy.org\/$arch\/\n' /etc/pacman.conf
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Set mirrors to global ones only
|
|
||||||
echo -e "Server = https://geo.mirror.pkgbuild.com/\$repo/os/\$arch\nServer = https://mirror.rackspace.com/archlinux/\$repo/os/\$arch" |
|
|
||||||
sudo tee /etc/pacman.d/mirrorlist >/dev/null
|
|
||||||
|
|
||||||
# Only add Chaotic-AUR if the architecture is x86_64 so ARM users can build the packages
|
|
||||||
if [[ "$(uname -m)" == "x86_64" ]] && [ -z "$DISABLE_CHAOTIC" ]; then
|
|
||||||
# Try installing Chaotic-AUR keyring and mirrorlist
|
|
||||||
if ! pacman-key --list-keys 3056513887B78AEB >/dev/null 2>&1 &&
|
|
||||||
sudo pacman-key --recv-key 3056513887B78AEB &&
|
|
||||||
sudo pacman-key --lsign-key 3056513887B78AEB &&
|
|
||||||
sudo pacman -U --noconfirm 'https://cdn-mirror.chaotic.cx/chaotic-aur/chaotic-keyring.pkg.tar.zst' &&
|
|
||||||
sudo pacman -U --noconfirm 'https://cdn-mirror.chaotic.cx/chaotic-aur/chaotic-mirrorlist.pkg.tar.zst'; then
|
|
||||||
|
|
||||||
# Add Chaotic-AUR repo to pacman config
|
|
||||||
if ! grep -q "chaotic-aur" /etc/pacman.conf; then
|
|
||||||
echo -e '\n[chaotic-aur]\nInclude = /etc/pacman.d/chaotic-mirrorlist' | sudo tee -a /etc/pacman.conf >/dev/null
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Refresh all repos
|
|
||||||
sudo pacman -Sy
|
|
||||||
else
|
|
||||||
echo -e "Failed to install Chaotic-AUR, so won't include it in pacman config!"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Allow repository index updates without sudo
|
|
||||||
sudo tee /etc/sudoers.d/repositories >/dev/null <<EOF
|
|
||||||
$USER ALL=(ALL) NOPASSWD: /usr/bin/pacman -Sy
|
|
||||||
EOF
|
|
||||||
sudo chmod 440 /etc/sudoers.d/repositories
|
|
||||||
@@ -24,7 +24,14 @@ catch_errors() {
|
|||||||
echo " ▀▀▀▀▀▀▀ ▀ ▀ ▀▀▀ ▀ ▀▀▀▀▀▀ "
|
echo " ▀▀▀▀▀▀▀ ▀ ▀ ▀▀▀ ▀ ▀▀▀▀▀▀ "
|
||||||
echo " "
|
echo " "
|
||||||
|
|
||||||
echo "You can retry by running: bash ~/.local/share/omarchy/install.sh"
|
if command -v gum >/dev/null && gum confirm "Retry installation?"; then
|
||||||
|
bash ~/.local/share/omarchy/install.sh
|
||||||
|
else
|
||||||
|
echo "You can retry later by running: bash ~/.local/share/omarchy/install.sh"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Ensure gum is available as early as possible to retry errors
|
||||||
|
sudo pacman -S --noconfirm gum
|
||||||
|
|
||||||
trap catch_errors ERR
|
trap catch_errors ERR
|
||||||
|
|||||||
14
install/reboot.sh
Normal file
14
install/reboot.sh
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
clear
|
||||||
|
tte -i ~/.local/share/omarchy/logo.txt --frame-rate 920 laseretch
|
||||||
|
echo
|
||||||
|
echo "You're done! So we're ready to reboot now..." | tte --frame-rate 640 wipe
|
||||||
|
|
||||||
|
if sudo test -f /etc/sudoers.d/99-omarchy-installer; then
|
||||||
|
sudo rm -f /etc/sudoers.d/99-omarchy-installer &>/dev/null
|
||||||
|
echo -e "\nRemember to remove USB installer!\n\n"
|
||||||
|
fi
|
||||||
|
|
||||||
|
sleep 5
|
||||||
|
reboot
|
||||||
@@ -9,6 +9,7 @@ omarchy-refresh-config uwsm/env
|
|||||||
echo -e "\n\e[31mOmarchy bins have been added to PATH (and OMARCHY_PATH is now system-wide).\nYou must immediately relaunch Hyprland or most Omarchy cmds won't work.\nPlease run Omarchy > Update again after the quick relaunch is complete.\e[0m"
|
echo -e "\n\e[31mOmarchy bins have been added to PATH (and OMARCHY_PATH is now system-wide).\nYou must immediately relaunch Hyprland or most Omarchy cmds won't work.\nPlease run Omarchy > Update again after the quick relaunch is complete.\e[0m"
|
||||||
echo
|
echo
|
||||||
|
|
||||||
|
mkdir -p ~/.local/state/omarchy/migrations
|
||||||
gum confirm "Ready to relaunch Hyprland? (All applications will be closed)" &&
|
gum confirm "Ready to relaunch Hyprland? (All applications will be closed)" &&
|
||||||
touch ~/.local/state/omarchy/migrations/1751134560.sh &&
|
touch ~/.local/state/omarchy/migrations/1751134560.sh &&
|
||||||
uwsm stop
|
uwsm stop
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
echo "Add Omarchy Package Repository"
|
echo "Add Omarchy Package Repository"
|
||||||
|
|
||||||
|
omarchy-refresh-pacman-mirrorlist
|
||||||
|
|
||||||
if ! grep -q "omarchy" /etc/pacman.conf; then
|
if ! grep -q "omarchy" /etc/pacman.conf; then
|
||||||
sudo sed -i '/^\[core\]/i [omarchy]\nSigLevel = Optional TrustAll\nServer = https:\/\/pkgs.omarchy.org\/$arch\/\n' /etc/pacman.conf
|
sudo sed -i '/^\[core\]/i [omarchy]\nSigLevel = Optional TrustAll\nServer = https:\/\/pkgs.omarchy.org\/$arch\n' /etc/pacman.conf
|
||||||
sudo systemctl restart systemd-timesyncd
|
sudo systemctl restart systemd-timesyncd
|
||||||
sudo pacman -Sy
|
sudo pacman -Syu --noconfirm
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
echo "Add missing installation of bat (used by the ff alias)"
|
echo "Add missing installation of bat (used by the ff alias)"
|
||||||
if ! command -v bat &>/dev/null; then
|
|
||||||
# Add missing installation of bat
|
omarchy-pkg-add bat
|
||||||
sudo pacman -S --noconfirm --needed bat
|
|
||||||
fi
|
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
echo "Installing missing fd terminal tool for finding files"
|
echo "Installing missing fd terminal tool for finding files"
|
||||||
|
|
||||||
if ! command -v fd &>/dev/null; then
|
omarchy-pkg-add fd
|
||||||
sudo pacman -S --noconfirm --needed fd
|
|
||||||
fi
|
|
||||||
|
|||||||
@@ -1,8 +1,9 @@
|
|||||||
echo "Switching from vlc to mpv for the default video player"
|
echo "Switching from vlc to mpv for the default video player"
|
||||||
if ! command -v mpv &>/dev/null; then
|
if omarchy-cmd-missing mpv; then
|
||||||
sudo pacman -Rns --noconfirm vlc
|
omarchy-pkg-drop vlc
|
||||||
rm ~/.local/share/applications/vlc.desktop
|
rm ~/.local/share/applications/vlc.desktop
|
||||||
sudo pacman -S --noconfirm mpv
|
|
||||||
|
omarchy-pkg-add mpv
|
||||||
xdg-mime default mpv.desktop video/mp4
|
xdg-mime default mpv.desktop video/mp4
|
||||||
xdg-mime default mpv.desktop video/x-msvideo
|
xdg-mime default mpv.desktop video/x-msvideo
|
||||||
xdg-mime default mpv.desktop video/x-matroska
|
xdg-mime default mpv.desktop video/x-matroska
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user