Compare commits
565 Commits
guard-agai
...
master
Author | SHA1 | Date | |
---|---|---|---|
d826cb0439 | |||
44abd5c932 | |||
25026672b7 | |||
583d3f15e4 | |||
1d1bdddb85 | |||
d7d82ae30c | |||
97a72e9dc8 | |||
a64a298181 | |||
19cc257a21 | |||
6fc1fb122d | |||
3d30f7a4ca | |||
6f7becc90a | |||
4c8abc7aba | |||
ae97d900ac | |||
adaaf14bce | |||
411ca42d29 | |||
b27d1fa5fa | |||
b7e56a0d57 | |||
cca3c51031 | |||
105164c1e4 | |||
965ceba9d2 | |||
![]() |
d5a340f6b7 | ||
![]() |
f0a12463a6 | ||
![]() |
acc1e2f757 | ||
![]() |
51f877ca1f | ||
![]() |
8167633824 | ||
![]() |
922acfd706 | ||
![]() |
b136cc5653 | ||
![]() |
52d1ac215d | ||
![]() |
838d0ca27b | ||
![]() |
f4ea58bdd0 | ||
![]() |
6c656766f8 | ||
![]() |
06e3cb4e71 | ||
![]() |
1506b98fe1 | ||
![]() |
2a8155cc68 | ||
![]() |
35b7f44c7e | ||
![]() |
4b70705252 | ||
![]() |
0eda27a3bc | ||
![]() |
c48f370924 | ||
![]() |
dcfbd7a2e5 | ||
![]() |
dde702a4c3 | ||
![]() |
9e0c638b84 | ||
![]() |
4e389007f1 | ||
![]() |
258b151935 | ||
![]() |
b80e4ce908 | ||
![]() |
31dbf49a1f | ||
![]() |
185807b771 | ||
![]() |
d8ddc5046f | ||
![]() |
5c6c880b0b | ||
![]() |
122bdd7837 | ||
![]() |
59088800ad | ||
![]() |
561ffcfb56 | ||
![]() |
b44661a0ad | ||
![]() |
a50041721c | ||
![]() |
88303d81fd | ||
![]() |
e99bab272f | ||
![]() |
b5ced14972 | ||
![]() |
e3bda8a970 | ||
![]() |
d031237b42 | ||
![]() |
0b48f08674 | ||
![]() |
63081e141a | ||
![]() |
249612bf67 | ||
![]() |
468a84b5cc | ||
![]() |
42ee87ad65 | ||
![]() |
f2844964c4 | ||
![]() |
b38e864f08 | ||
![]() |
b4f6bbda4d | ||
![]() |
e806080c4d | ||
![]() |
fe2dd66f91 | ||
![]() |
062c6b3dce | ||
![]() |
68a51c18a8 | ||
![]() |
5a98771e5b | ||
![]() |
77863a4c12 | ||
![]() |
5b59aee51e | ||
![]() |
fdaa126aee | ||
![]() |
4f0dfcc865 | ||
![]() |
2635534778 | ||
![]() |
5bb7b66dee | ||
![]() |
b8f4a10056 | ||
![]() |
86b03357d0 | ||
![]() |
186912ca1d | ||
![]() |
c7d9581d7b | ||
![]() |
03503364cc | ||
![]() |
44529a7a25 | ||
![]() |
705b6858dc | ||
![]() |
b9758a9c8c | ||
![]() |
0a0843c7ec | ||
![]() |
ec0af90c98 | ||
![]() |
37f0c18b78 | ||
![]() |
1ec6ba61dc | ||
![]() |
066ec7ffff | ||
![]() |
c73c1c90bf | ||
![]() |
256a49ee53 | ||
![]() |
39e0cf3a37 | ||
![]() |
e8f932b0f6 | ||
![]() |
55daa135a7 | ||
![]() |
a428208077 | ||
![]() |
2d848338e6 | ||
![]() |
925a2906e5 | ||
![]() |
f98899e4e2 | ||
![]() |
e565768bed | ||
![]() |
661eed2640 | ||
![]() |
28ba0bff7a | ||
![]() |
bdfc0fad5d | ||
![]() |
ec17b3f012 | ||
![]() |
9cd70e9aff | ||
![]() |
51f5bed286 | ||
![]() |
9a98782342 | ||
![]() |
c0a091e293 | ||
![]() |
d7fa8181fa | ||
![]() |
dfda4f895a | ||
![]() |
a67fc717c1 | ||
![]() |
599b58f9a1 | ||
![]() |
f14810e80d | ||
![]() |
3bf51d30ff | ||
![]() |
39dccccb1a | ||
![]() |
46f8b522f1 | ||
![]() |
1576c4e5c6 | ||
![]() |
f39dc9a269 | ||
![]() |
ff6802830c | ||
![]() |
af9ab9069f | ||
![]() |
3363fe0544 | ||
![]() |
1577620344 | ||
![]() |
d183daff1a | ||
![]() |
5ed08ef5b9 | ||
![]() |
ae8c76f582 | ||
![]() |
93ef034a5c | ||
![]() |
fc43706190 | ||
![]() |
fc853ffe96 | ||
![]() |
a8c3d1a2bd | ||
![]() |
b09c625ac0 | ||
![]() |
4d28721682 | ||
![]() |
5ad441e539 | ||
![]() |
78e81d7534 | ||
![]() |
00ce49a4ac | ||
![]() |
78719b0552 | ||
![]() |
8a5bca3807 | ||
![]() |
78aeb91e5f | ||
![]() |
83b67d0d6b | ||
![]() |
ed9edab8ed | ||
![]() |
115e9c5af8 | ||
![]() |
00cc8315a6 | ||
![]() |
1d915c6583 | ||
![]() |
dd493b0cdf | ||
![]() |
1f4723ae33 | ||
![]() |
478b166ae7 | ||
![]() |
c0770fc7a3 | ||
![]() |
846b2e2595 | ||
![]() |
d8a4640010 | ||
![]() |
ee5f4eb925 | ||
![]() |
cb22afdb93 | ||
![]() |
d2bd1b47b6 | ||
![]() |
02134df8ee | ||
![]() |
cd39a145e8 | ||
![]() |
a0c3a435fc | ||
![]() |
f0a77e65cd | ||
![]() |
4de9f5fda3 | ||
![]() |
1efe4a819f | ||
![]() |
a29237e070 | ||
![]() |
9834a40796 | ||
![]() |
edf0bb3128 | ||
![]() |
960cbbd591 | ||
![]() |
c974c3dbc4 | ||
![]() |
f1af28f10d | ||
![]() |
673cea1644 | ||
![]() |
9d739faf2b | ||
![]() |
69afedf380 | ||
![]() |
57e14afca3 | ||
![]() |
38d9961622 | ||
![]() |
57b1180c67 | ||
![]() |
664fb7c51a | ||
![]() |
09a90e3cf2 | ||
![]() |
6dd95e71bf | ||
![]() |
22769caa8c | ||
![]() |
448be1317f | ||
![]() |
7bd1d56399 | ||
![]() |
b094557a97 | ||
![]() |
3f895969c7 | ||
![]() |
da7222f510 | ||
![]() |
9d355091b5 | ||
![]() |
a391b64e61 | ||
![]() |
028c07d016 | ||
![]() |
4fd6a110ea | ||
![]() |
92a491fd47 | ||
![]() |
8b192c30e1 | ||
![]() |
6826cad95b | ||
![]() |
1e46882fd8 | ||
![]() |
b0acd0b5e8 | ||
![]() |
24682aea8c | ||
![]() |
bb43d719e6 | ||
![]() |
c4b32c047a | ||
![]() |
f4ef8eca65 | ||
![]() |
1d6d21e7b7 | ||
![]() |
04fff555b8 | ||
![]() |
aa32b147ad | ||
![]() |
6b3b93ded1 | ||
![]() |
9dbef029f6 | ||
![]() |
aaefc4f208 | ||
![]() |
ccf13e5902 | ||
![]() |
9ed755b445 | ||
![]() |
42432ae462 | ||
![]() |
438156e36f | ||
![]() |
574d213c34 | ||
![]() |
7d61c19f69 | ||
![]() |
69fe4ae997 | ||
![]() |
c3af4b9469 | ||
![]() |
ffe8997fad | ||
![]() |
e2611d9bc4 | ||
![]() |
266767df5f | ||
![]() |
eb4172a486 | ||
![]() |
ca115b9061 | ||
![]() |
ab09446971 | ||
![]() |
af0f459a1a | ||
![]() |
fbf9a19574 | ||
![]() |
95139164a3 | ||
![]() |
2ae973108d | ||
![]() |
aa0b44b7f4 | ||
![]() |
d9424b2bff | ||
![]() |
36a30dd01d | ||
![]() |
82467892a3 | ||
![]() |
e138f7e8eb | ||
![]() |
0a75644f2d | ||
![]() |
3725f2d3b6 | ||
![]() |
0ebd62a32e | ||
![]() |
31d97335fc | ||
![]() |
41a1fe6b21 | ||
![]() |
91e686f1b2 | ||
![]() |
75ac6910d4 | ||
![]() |
b4b8788c14 | ||
![]() |
76c94e2604 | ||
![]() |
e59a98fb0b | ||
![]() |
dee7e3e4a7 | ||
![]() |
5a7b9292c8 | ||
![]() |
31ce6f689e | ||
![]() |
210481d758 | ||
![]() |
3bac37b21b | ||
![]() |
1edbe89191 | ||
![]() |
617e96234b | ||
![]() |
5873980703 | ||
![]() |
b8cc8d8bc3 | ||
![]() |
455fe890ec | ||
![]() |
ccc8aa87d0 | ||
![]() |
193797393f | ||
![]() |
7056a3903a | ||
![]() |
3880c49469 | ||
![]() |
87467579f7 | ||
![]() |
6147b634e7 | ||
![]() |
9bb5832646 | ||
![]() |
07bf9b838a | ||
![]() |
332c8d5abb | ||
![]() |
022b591986 | ||
![]() |
7713534693 | ||
![]() |
bf72d80ac6 | ||
![]() |
d0092f00c8 | ||
![]() |
75cd9fefa5 | ||
![]() |
07ad23b303 | ||
![]() |
098c9157d8 | ||
![]() |
5e3d0d89a5 | ||
![]() |
d4403051cf | ||
![]() |
cc80782160 | ||
![]() |
318a6e23cf | ||
![]() |
a4119ce43e | ||
![]() |
cc4d41bdaa | ||
![]() |
b2a2d0fde3 | ||
![]() |
2cb7f61108 | ||
![]() |
acca058d4c | ||
![]() |
29ea8af5e1 | ||
![]() |
3381bcca59 | ||
![]() |
0f2479f3f6 | ||
![]() |
b8bd1d1d6c | ||
![]() |
85f9fb486e | ||
![]() |
04aa3cca0d | ||
![]() |
8c1fd76a37 | ||
![]() |
7c4156fc9d | ||
![]() |
78b1238f40 | ||
![]() |
9ecac600e7 | ||
![]() |
74096d5f6c | ||
![]() |
6366dc1118 | ||
![]() |
e7ea45a802 | ||
![]() |
8074694ac8 | ||
![]() |
b3d24a1b13 | ||
![]() |
cab64fa9de | ||
![]() |
b09ba8d6d3 | ||
![]() |
9f49f869a3 | ||
![]() |
c3b58bc773 | ||
![]() |
58d6b5ba7f | ||
![]() |
13166960a1 | ||
![]() |
e33219f611 | ||
![]() |
44d6314929 | ||
![]() |
450403e48a | ||
![]() |
fbc60d9ec3 | ||
![]() |
7d427faad0 | ||
![]() |
5d155b712a | ||
![]() |
2cca02699a | ||
![]() |
4a1888af8f | ||
![]() |
53217c4c83 | ||
![]() |
7665ac4fde | ||
![]() |
0246468403 | ||
![]() |
3a0bb502b6 | ||
![]() |
b2161f1f31 | ||
![]() |
cf556b2da2 | ||
![]() |
8e557b2ae5 | ||
![]() |
041c787b56 | ||
![]() |
16b0919418 | ||
![]() |
1942ac68dc | ||
![]() |
9375dfca21 | ||
![]() |
04f89061ac | ||
![]() |
e7b00295ec | ||
![]() |
3e7509071b | ||
![]() |
322fa8421e | ||
![]() |
5381185121 | ||
![]() |
2a840ea085 | ||
![]() |
bac5710707 | ||
![]() |
3f921ef4f8 | ||
![]() |
bc08c47157 | ||
![]() |
a60bcaf7a1 | ||
![]() |
8a78566248 | ||
![]() |
5534e33dc0 | ||
![]() |
bf31373840 | ||
![]() |
40e10b1594 | ||
![]() |
9bf1edac9f | ||
![]() |
d4fa028cf3 | ||
![]() |
0a13ad8ef8 | ||
![]() |
4e12e796f2 | ||
![]() |
76082b945d | ||
![]() |
65636b0ba8 | ||
![]() |
41677ad7e1 | ||
![]() |
8e4baa6cd1 | ||
![]() |
a1cd10c0a2 | ||
![]() |
7e6854124c | ||
![]() |
020d1309b0 | ||
![]() |
7721a0efca | ||
![]() |
87045ef128 | ||
![]() |
b1a5facd42 | ||
![]() |
cedf20eb36 | ||
![]() |
84420db026 | ||
![]() |
092b2ba51c | ||
![]() |
21f60a960b | ||
![]() |
6de4591a28 | ||
![]() |
ee1ee526d7 | ||
![]() |
12ab446715 | ||
![]() |
d00160464f | ||
![]() |
9e4078d7da | ||
![]() |
7b93bace81 | ||
![]() |
07a2423298 | ||
![]() |
81cac3bbb7 | ||
![]() |
79104373bd | ||
![]() |
bfa91b8917 | ||
![]() |
8942b33d94 | ||
![]() |
0e4b9ee6f9 | ||
![]() |
de28805881 | ||
![]() |
bc43377cc6 | ||
![]() |
e99dc3b67c | ||
![]() |
2a7a9b67aa | ||
![]() |
5dec0daf4b | ||
![]() |
0eca37f3ff | ||
![]() |
ccf6afc36c | ||
![]() |
ce5178c285 | ||
![]() |
2e071465a0 | ||
![]() |
7535e0ad0a | ||
![]() |
e6c1a52341 | ||
![]() |
a712a0906a | ||
![]() |
40d850fdb3 | ||
![]() |
50c5f742dd | ||
![]() |
55330cce88 | ||
![]() |
7ca72c598a | ||
![]() |
787296edab | ||
![]() |
029a3a3d37 | ||
![]() |
d5ee754538 | ||
![]() |
1b69700999 | ||
![]() |
accc7a903e | ||
![]() |
377f3e6d83 | ||
![]() |
f06b1801d5 | ||
![]() |
aca23ad834 | ||
![]() |
2db5e730a7 | ||
![]() |
bd2eddbab4 | ||
![]() |
f456e21cab | ||
![]() |
5aa26eb9bd | ||
![]() |
589ffb21fe | ||
![]() |
5a809db2a8 | ||
![]() |
75a8b1fc83 | ||
![]() |
2847ed270f | ||
![]() |
bf49a86e98 | ||
![]() |
a9d70e6879 | ||
![]() |
1ecbd22fb3 | ||
![]() |
8cee2d3a8b | ||
![]() |
9b25a2fa13 | ||
![]() |
d4829bbc33 | ||
![]() |
5e1a4da33d | ||
![]() |
b0e99fc865 | ||
![]() |
1d483dac8b | ||
![]() |
8a9b841e92 | ||
![]() |
59e4981df7 | ||
![]() |
f0f4569aa2 | ||
![]() |
b15dde2dc9 | ||
![]() |
6634e28540 | ||
![]() |
f8482fdad7 | ||
![]() |
03c6b0af3d | ||
![]() |
bc323ca267 | ||
![]() |
d26e3e368d | ||
![]() |
3d283eac18 | ||
![]() |
ac207720f8 | ||
![]() |
07e3818b4f | ||
![]() |
9e7e5a1512 | ||
![]() |
171ca57908 | ||
![]() |
ae910df769 | ||
![]() |
78de5c24c9 | ||
![]() |
04e9e4c21f | ||
![]() |
fc3467a66e | ||
![]() |
12b2950853 | ||
![]() |
1e924d1794 | ||
![]() |
d0a2f63322 | ||
![]() |
ac37fb7ccd | ||
![]() |
4e136ded68 | ||
![]() |
add56181d7 | ||
![]() |
a46f652487 | ||
![]() |
98332f624b | ||
![]() |
7e30335a2e | ||
![]() |
4c4aafe670 | ||
![]() |
7893f803e0 | ||
![]() |
c407c4c590 | ||
![]() |
1e54f06570 | ||
![]() |
793b346d1d | ||
![]() |
539eb240be | ||
![]() |
d75cac05c8 | ||
![]() |
79bdb151d1 | ||
![]() |
4be9053d68 | ||
![]() |
b933f1f4cd | ||
![]() |
cd8a6bb29a | ||
![]() |
6f6c50c573 | ||
![]() |
6dd7829886 | ||
![]() |
26e3cc0b8c | ||
![]() |
16c671adf0 | ||
![]() |
46fbe16dd4 | ||
![]() |
08982922eb | ||
![]() |
31ab6b4952 | ||
![]() |
76c7956d15 | ||
![]() |
e6a253efaa | ||
![]() |
389f02e6ed | ||
![]() |
ccbe7c817b | ||
![]() |
1dc3330480 | ||
![]() |
bc6fa48155 | ||
![]() |
06103d4258 | ||
![]() |
e0edb8c660 | ||
![]() |
30e7a323b8 | ||
![]() |
1c5a17f852 | ||
![]() |
c8e848530a | ||
![]() |
b6a1d7643d | ||
![]() |
854a9e6427 | ||
![]() |
6c4571f2ca | ||
![]() |
7a1976a659 | ||
![]() |
99d3cc113e | ||
![]() |
c5a91b1e0f | ||
![]() |
6a26a37c48 | ||
![]() |
03a4223be9 | ||
![]() |
d12b194227 | ||
![]() |
ddf9498f0a | ||
![]() |
ba40f6349e | ||
![]() |
0fd360e94f | ||
![]() |
199a9c805d | ||
![]() |
34ccff4cf6 | ||
![]() |
0aedef58c9 | ||
![]() |
f67cb1dbff | ||
![]() |
c61ef71653 | ||
![]() |
5be5dede6b | ||
![]() |
7d3d7e264b | ||
![]() |
7929988901 | ||
![]() |
cb6134076f | ||
![]() |
0a3916011c | ||
![]() |
4b6e8962ca | ||
![]() |
1d2fe96916 | ||
![]() |
36013ec2d9 | ||
![]() |
1104951d7a | ||
![]() |
eb604e3e54 | ||
![]() |
5049640cfe | ||
![]() |
ab43b036a1 | ||
![]() |
86c967352b | ||
![]() |
7e28038687 | ||
![]() |
d9d847fd71 | ||
![]() |
a23a48594f | ||
![]() |
a5dacd5c1d | ||
![]() |
8d20626534 | ||
![]() |
72a1d81d20 | ||
![]() |
610ec4a398 | ||
![]() |
7e4da388bf | ||
![]() |
b2eb1b08a4 | ||
![]() |
94aa9b688f | ||
![]() |
dfe7ea24b3 | ||
![]() |
41ba61b760 | ||
![]() |
4fb0d59a82 | ||
![]() |
4c4792f36f | ||
![]() |
e8d98c6418 | ||
![]() |
af00a902cd | ||
![]() |
38bf472dbd | ||
![]() |
d23ce0f914 | ||
![]() |
b40a5a9a9f | ||
![]() |
4237807bc1 | ||
![]() |
4df374205f | ||
![]() |
2e6e1c5bca | ||
![]() |
616381833c | ||
![]() |
06345c7e25 | ||
![]() |
1484cbb7d7 | ||
![]() |
528ab6bfd7 | ||
![]() |
6015b9c6ef | ||
![]() |
f6d5df5a89 | ||
![]() |
f06dd90429 | ||
![]() |
f63e777c9a | ||
![]() |
0b31f3139f | ||
![]() |
90ba44f725 | ||
![]() |
abc0005893 | ||
![]() |
ba0666999e | ||
![]() |
c07c5652cb | ||
![]() |
9d561fe34d | ||
![]() |
4ab3ff8349 | ||
![]() |
9ae0af7b21 | ||
![]() |
61032ba4d0 | ||
![]() |
32e091d2e5 | ||
![]() |
4d94f02584 | ||
![]() |
f23e844340 | ||
![]() |
e567e9ee8a | ||
![]() |
b0f48ca585 | ||
![]() |
375210f5c8 | ||
![]() |
0c1419b725 | ||
![]() |
5624fc7e5e | ||
![]() |
eb589b012e | ||
![]() |
1b485efcf5 | ||
![]() |
c97de217b3 | ||
![]() |
3566ecfc89 | ||
![]() |
27607c1573 | ||
![]() |
aa3195385d | ||
![]() |
3db8028315 | ||
![]() |
f4ff108038 | ||
![]() |
f33d004bc9 | ||
![]() |
4f1a87c7e3 | ||
![]() |
567b05c489 | ||
![]() |
3d489382e4 | ||
![]() |
485805fab3 | ||
![]() |
cbb9cc22e5 | ||
![]() |
c7e5428df9 | ||
![]() |
67e0b6a4e0 | ||
![]() |
631c2071b7 | ||
![]() |
a49bd12f44 | ||
![]() |
4ab46ef687 | ||
![]() |
9dc12c1d3e | ||
![]() |
af84d085f0 | ||
![]() |
1cd6feed43 | ||
![]() |
39f8add864 | ||
![]() |
fe92a78f21 | ||
![]() |
6c75e705e8 | ||
![]() |
7bb9214c66 | ||
![]() |
7eb661c9c8 | ||
![]() |
666dbd8f39 | ||
![]() |
308033bd10 | ||
![]() |
4a468041cb | ||
![]() |
97e3902455 | ||
![]() |
b75065c4cf | ||
![]() |
8c8cf7aadb | ||
![]() |
722fa73bc8 | ||
![]() |
6b8917450f | ||
![]() |
26b09bb218 | ||
![]() |
46d58ff0df | ||
![]() |
08bc9fcaea | ||
![]() |
81df3ce171 | ||
![]() |
0fcda80630 | ||
![]() |
6348a0ad08 |
@ -1,11 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Version=1.0
|
|
||||||
Name=About
|
|
||||||
Comment=System information from Fastfetch
|
|
||||||
Exec=alacritty --class=About --title=About -e bash -c 'fastfetch; read -n 1 -s'
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
Icon=Arch
|
|
||||||
Categories=GTK;
|
|
||||||
StartupNotify=false
|
|
||||||
|
|
@ -1,11 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Version=1.0
|
|
||||||
Name=Activity
|
|
||||||
Comment=System activity from btop
|
|
||||||
Exec=alacritty --class=Activity --title=Activity -e btop
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
Icon=Activity
|
|
||||||
Categories=GTK;
|
|
||||||
StartupNotify=false
|
|
||||||
|
|
@ -1,11 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Version=1.0
|
|
||||||
Name=Docker
|
|
||||||
Comment=Manage Docker containers with LazyDocker
|
|
||||||
Exec=alacritty --class=Docker --title=Docker -e lazydocker
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
Icon=Docker
|
|
||||||
Categories=GTK;
|
|
||||||
StartupNotify=false
|
|
||||||
|
|
@ -1,221 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Version=1.0
|
|
||||||
Name=Chromium
|
|
||||||
# Only KDE 4 seems to use GenericName, so we reuse the KDE strings.
|
|
||||||
# From Ubuntu's language-pack-kde-XX-base packages, version 9.04-20090413.
|
|
||||||
GenericName=Web Browser
|
|
||||||
GenericName[ar]=متصفح الشبكة
|
|
||||||
GenericName[bg]=Уеб браузър
|
|
||||||
GenericName[ca]=Navegador web
|
|
||||||
GenericName[cs]=WWW prohlížeč
|
|
||||||
GenericName[da]=Browser
|
|
||||||
GenericName[de]=Web-Browser
|
|
||||||
GenericName[el]=Περιηγητής ιστού
|
|
||||||
GenericName[en_GB]=Web Browser
|
|
||||||
GenericName[es]=Navegador web
|
|
||||||
GenericName[et]=Veebibrauser
|
|
||||||
GenericName[fi]=WWW-selain
|
|
||||||
GenericName[fr]=Navigateur Web
|
|
||||||
GenericName[gu]=વેબ બ્રાઉઝર
|
|
||||||
GenericName[he]=דפדפן אינטרנט
|
|
||||||
GenericName[hi]=वेब ब्राउज़र
|
|
||||||
GenericName[hu]=Webböngésző
|
|
||||||
GenericName[it]=Browser Web
|
|
||||||
GenericName[ja]=ウェブブラウザ
|
|
||||||
GenericName[kn]=ಜಾಲ ವೀಕ್ಷಕ
|
|
||||||
GenericName[ko]=웹 브라우저
|
|
||||||
GenericName[lt]=Žiniatinklio naršyklė
|
|
||||||
GenericName[lv]=Tīmekļa pārlūks
|
|
||||||
GenericName[ml]=വെബ് ബ്രൌസര്
|
|
||||||
GenericName[mr]=वेब ब्राऊजर
|
|
||||||
GenericName[nb]=Nettleser
|
|
||||||
GenericName[nl]=Webbrowser
|
|
||||||
GenericName[pl]=Przeglądarka WWW
|
|
||||||
GenericName[pt]=Navegador Web
|
|
||||||
GenericName[pt_BR]=Navegador da Internet
|
|
||||||
GenericName[ro]=Navigator de Internet
|
|
||||||
GenericName[ru]=Веб-браузер
|
|
||||||
GenericName[sl]=Spletni brskalnik
|
|
||||||
GenericName[sv]=Webbläsare
|
|
||||||
GenericName[ta]=இணைய உலாவி
|
|
||||||
GenericName[th]=เว็บเบราว์เซอร์
|
|
||||||
GenericName[tr]=Web Tarayıcı
|
|
||||||
GenericName[uk]=Навігатор Тенет
|
|
||||||
GenericName[zh_CN]=网页浏览器
|
|
||||||
GenericName[zh_HK]=網頁瀏覽器
|
|
||||||
GenericName[zh_TW]=網頁瀏覽器
|
|
||||||
# Not translated in KDE, from Epiphany 2.26.1-0ubuntu1.
|
|
||||||
GenericName[bn]=ওয়েব ব্রাউজার
|
|
||||||
GenericName[fil]=Web Browser
|
|
||||||
GenericName[hr]=Web preglednik
|
|
||||||
GenericName[id]=Browser Web
|
|
||||||
GenericName[or]=ଓ୍ବେବ ବ୍ରାଉଜର
|
|
||||||
GenericName[sk]=WWW prehliadač
|
|
||||||
GenericName[sr]=Интернет прегледник
|
|
||||||
GenericName[te]=మహాతల అన్వేషి
|
|
||||||
GenericName[vi]=Bộ duyệt Web
|
|
||||||
# Gnome and KDE 3 uses Comment.
|
|
||||||
Comment=Access the Internet
|
|
||||||
Comment[ar]=الدخول إلى الإنترنت
|
|
||||||
Comment[bg]=Достъп до интернет
|
|
||||||
Comment[bn]=ইন্টারনেটটি অ্যাক্সেস করুন
|
|
||||||
Comment[ca]=Accedeix a Internet
|
|
||||||
Comment[cs]=Přístup k internetu
|
|
||||||
Comment[da]=Få adgang til internettet
|
|
||||||
Comment[de]=Internetzugriff
|
|
||||||
Comment[el]=Πρόσβαση στο Διαδίκτυο
|
|
||||||
Comment[en_GB]=Access the Internet
|
|
||||||
Comment[es]=Accede a Internet.
|
|
||||||
Comment[et]=Pääs Internetti
|
|
||||||
Comment[fi]=Käytä internetiä
|
|
||||||
Comment[fil]=I-access ang Internet
|
|
||||||
Comment[fr]=Accéder à Internet
|
|
||||||
Comment[gu]=ઇંટરનેટ ઍક્સેસ કરો
|
|
||||||
Comment[he]=גישה אל האינטרנט
|
|
||||||
Comment[hi]=इंटरनेट तक पहुंच स्थापित करें
|
|
||||||
Comment[hr]=Pristup Internetu
|
|
||||||
Comment[hu]=Internetelérés
|
|
||||||
Comment[id]=Akses Internet
|
|
||||||
Comment[it]=Accesso a Internet
|
|
||||||
Comment[ja]=インターネットにアクセス
|
|
||||||
Comment[kn]=ಇಂಟರ್ನೆಟ್ ಅನ್ನು ಪ್ರವೇಶಿಸಿ
|
|
||||||
Comment[ko]=인터넷 연결
|
|
||||||
Comment[lt]=Interneto prieiga
|
|
||||||
Comment[lv]=Piekļūt internetam
|
|
||||||
Comment[ml]=ഇന്റര്നെറ്റ് ആക്സസ് ചെയ്യുക
|
|
||||||
Comment[mr]=इंटरनेटमध्ये प्रवेश करा
|
|
||||||
Comment[nb]=Gå til Internett
|
|
||||||
Comment[nl]=Verbinding maken met internet
|
|
||||||
Comment[or]=ଇଣ୍ଟର୍ନେଟ୍ ପ୍ରବେଶ କରନ୍ତୁ
|
|
||||||
Comment[pl]=Skorzystaj z internetu
|
|
||||||
Comment[pt]=Aceder à Internet
|
|
||||||
Comment[pt_BR]=Acessar a internet
|
|
||||||
Comment[ro]=Accesaţi Internetul
|
|
||||||
Comment[ru]=Доступ в Интернет
|
|
||||||
Comment[sk]=Prístup do siete Internet
|
|
||||||
Comment[sl]=Dostop do interneta
|
|
||||||
Comment[sr]=Приступите Интернету
|
|
||||||
Comment[sv]=Gå ut på Internet
|
|
||||||
Comment[ta]=இணையத்தை அணுகுதல்
|
|
||||||
Comment[te]=ఇంటర్నెట్ను ఆక్సెస్ చెయ్యండి
|
|
||||||
Comment[th]=เข้าถึงอินเทอร์เน็ต
|
|
||||||
Comment[tr]=İnternet'e erişin
|
|
||||||
Comment[uk]=Доступ до Інтернету
|
|
||||||
Comment[vi]=Truy cập Internet
|
|
||||||
Comment[zh_CN]=访问互联网
|
|
||||||
Comment[zh_HK]=連線到網際網路
|
|
||||||
Comment[zh_TW]=連線到網際網路
|
|
||||||
Exec=/usr/bin/chromium --ozone-platform=wayland %U
|
|
||||||
StartupNotify=true
|
|
||||||
Terminal=false
|
|
||||||
Icon=chromium
|
|
||||||
Type=Application
|
|
||||||
Categories=Network;WebBrowser;
|
|
||||||
MimeType=application/pdf;application/rdf+xml;application/rss+xml;application/xhtml+xml;application/xhtml_xml;application/xml;image/gif;image/jpeg;image/png;image/webp;text/html;text/xml;x-scheme-handler/http;x-scheme-handler/https;
|
|
||||||
Actions=new-window;new-private-window;
|
|
||||||
|
|
||||||
[Desktop Action new-window]
|
|
||||||
Name=New Window
|
|
||||||
Name[am]=አዲስ መስኮት
|
|
||||||
Name[ar]=نافذة جديدة
|
|
||||||
Name[bg]=Нов прозорец
|
|
||||||
Name[bn]=নতুন উইন্ডো
|
|
||||||
Name[ca]=Finestra nova
|
|
||||||
Name[cs]=Nové okno
|
|
||||||
Name[da]=Nyt vindue
|
|
||||||
Name[de]=Neues Fenster
|
|
||||||
Name[el]=Νέο Παράθυρο
|
|
||||||
Name[en_GB]=New Window
|
|
||||||
Name[es]=Nueva ventana
|
|
||||||
Name[et]=Uus aken
|
|
||||||
Name[fa]=پنجره جدید
|
|
||||||
Name[fi]=Uusi ikkuna
|
|
||||||
Name[fil]=New Window
|
|
||||||
Name[fr]=Nouvelle fenêtre
|
|
||||||
Name[gu]=નવી વિંડો
|
|
||||||
Name[hi]=नई विंडो
|
|
||||||
Name[hr]=Novi prozor
|
|
||||||
Name[hu]=Új ablak
|
|
||||||
Name[id]=Jendela Baru
|
|
||||||
Name[it]=Nuova finestra
|
|
||||||
Name[iw]=חלון חדש
|
|
||||||
Name[ja]=新規ウインドウ
|
|
||||||
Name[kn]=ಹೊಸ ವಿಂಡೊ
|
|
||||||
Name[ko]=새 창
|
|
||||||
Name[lt]=Naujas langas
|
|
||||||
Name[lv]=Jauns logs
|
|
||||||
Name[ml]=പുതിയ വിന്ഡോ
|
|
||||||
Name[mr]=नवीन विंडो
|
|
||||||
Name[nl]=Nieuw venster
|
|
||||||
Name[no]=Nytt vindu
|
|
||||||
Name[pl]=Nowe okno
|
|
||||||
Name[pt]=Nova janela
|
|
||||||
Name[pt_BR]=Nova janela
|
|
||||||
Name[ro]=Fereastră nouă
|
|
||||||
Name[ru]=Новое окно
|
|
||||||
Name[sk]=Nové okno
|
|
||||||
Name[sl]=Novo okno
|
|
||||||
Name[sr]=Нови прозор
|
|
||||||
Name[sv]=Nytt fönster
|
|
||||||
Name[sw]=Dirisha Jipya
|
|
||||||
Name[ta]=புதிய சாளரம்
|
|
||||||
Name[te]=క్రొత్త విండో
|
|
||||||
Name[th]=หน้าต่างใหม่
|
|
||||||
Name[tr]=Yeni Pencere
|
|
||||||
Name[uk]=Нове вікно
|
|
||||||
Name[vi]=Cửa sổ Mới
|
|
||||||
Name[zh_CN]=新建窗口
|
|
||||||
Name[zh_TW]=開新視窗
|
|
||||||
Exec=/usr/bin/chromium --ozone-platform=wayland --new-window
|
|
||||||
|
|
||||||
[Desktop Action new-private-window]
|
|
||||||
Name=New Incognito Window
|
|
||||||
Name[ar]=نافذة جديدة للتصفح المتخفي
|
|
||||||
Name[bg]=Нов прозорец „инкогнито“
|
|
||||||
Name[bn]=নতুন ছদ্মবেশী উইন্ডো
|
|
||||||
Name[ca]=Finestra d'incògnit nova
|
|
||||||
Name[cs]=Nové anonymní okno
|
|
||||||
Name[da]=Nyt inkognitovindue
|
|
||||||
Name[de]=Neues Inkognito-Fenster
|
|
||||||
Name[el]=Νέο παράθυρο για ανώνυμη περιήγηση
|
|
||||||
Name[en_GB]=New Incognito window
|
|
||||||
Name[es]=Nueva ventana de incógnito
|
|
||||||
Name[et]=Uus inkognito aken
|
|
||||||
Name[fa]=پنجره جدید حالت ناشناس
|
|
||||||
Name[fi]=Uusi incognito-ikkuna
|
|
||||||
Name[fil]=Bagong Incognito window
|
|
||||||
Name[fr]=Nouvelle fenêtre de navigation privée
|
|
||||||
Name[gu]=નવી છુપી વિંડો
|
|
||||||
Name[hi]=नई गुप्त विंडो
|
|
||||||
Name[hr]=Novi anoniman prozor
|
|
||||||
Name[hu]=Új Inkognitóablak
|
|
||||||
Name[id]=Jendela Penyamaran baru
|
|
||||||
Name[it]=Nuova finestra di navigazione in incognito
|
|
||||||
Name[iw]=חלון חדש לגלישה בסתר
|
|
||||||
Name[ja]=新しいシークレット ウィンドウ
|
|
||||||
Name[kn]=ಹೊಸ ಅಜ್ಞಾತ ವಿಂಡೋ
|
|
||||||
Name[ko]=새 시크릿 창
|
|
||||||
Name[lt]=Naujas inkognito langas
|
|
||||||
Name[lv]=Jauns inkognito režīma logs
|
|
||||||
Name[ml]=പുതിയ വേഷ പ്രച്ഛന്ന വിന്ഡോ
|
|
||||||
Name[mr]=नवीन गुप्त विंडो
|
|
||||||
Name[nl]=Nieuw incognitovenster
|
|
||||||
Name[no]=Nytt inkognitovindu
|
|
||||||
Name[pl]=Nowe okno incognito
|
|
||||||
Name[pt]=Nova janela de navegação anónima
|
|
||||||
Name[pt_BR]=Nova janela anônima
|
|
||||||
Name[ro]=Fereastră nouă incognito
|
|
||||||
Name[ru]=Новое окно в режиме инкогнито
|
|
||||||
Name[sk]=Nové okno inkognito
|
|
||||||
Name[sl]=Novo okno brez beleženja zgodovine
|
|
||||||
Name[sr]=Нови прозор за прегледање без архивирања
|
|
||||||
Name[sv]=Nytt inkognitofönster
|
|
||||||
Name[ta]=புதிய மறைநிலைச் சாளரம்
|
|
||||||
Name[te]=క్రొత్త అజ్ఞాత విండో
|
|
||||||
Name[th]=หน้าต่างใหม่ที่ไม่ระบุตัวตน
|
|
||||||
Name[tr]=Yeni Gizli pencere
|
|
||||||
Name[uk]=Нове вікно в режимі анонімного перегляду
|
|
||||||
Name[vi]=Cửa sổ ẩn danh mới
|
|
||||||
Name[zh_CN]=新建隐身窗口
|
|
||||||
Name[zh_TW]=新增無痕式視窗
|
|
||||||
Exec=/usr/bin/chromium --ozone-platform=wayland --new-window --incognito
|
|
Binary file not shown.
Before Width: | Height: | Size: 38 KiB |
Binary file not shown.
Before Width: | Height: | Size: 19 KiB |
Binary file not shown.
Before Width: | Height: | Size: 21 KiB |
@ -1,7 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Name=Audio Settings
|
|
||||||
Comment=Using Wiremix
|
|
||||||
Exec=alacritty --class=Wiremix --title=Wiremix -e wiremix
|
|
||||||
Icon=audio-card
|
|
||||||
Type=Application
|
|
||||||
Terminal=false
|
|
@ -1,12 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Name=Zoom
|
|
||||||
Comment=Zoom Video Conference
|
|
||||||
Exec=env QT_SCALE_FACTOR=2 /usr/bin/zoom %U
|
|
||||||
Icon=Zoom
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
Encoding=UTF-8
|
|
||||||
Categories=Network;Application;
|
|
||||||
StartupWMClass=zoom
|
|
||||||
MimeType=x-scheme-handler/zoommtg;x-scheme-handler/zoomus;x-scheme-handler/tel;x-scheme-handler/callto;x-scheme-handler/zoomphonecall;x-scheme-handler/zoomphonesms;x-scheme-handler/zoomcontactcentercall;application/x-zoom
|
|
||||||
X-KDE-Protocols=zoommtg;zoomus;tel;callto;zoomphonecall;zoomphonesms;zoomcontactcentercall;
|
|
30
bin/comarchy-toggle-disable-internal-monitor
Executable file
30
bin/comarchy-toggle-disable-internal-monitor
Executable file
@ -0,0 +1,30 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -u
|
||||||
|
|
||||||
|
# internal monitor name - change if yours differs
|
||||||
|
INT="eDP-1"
|
||||||
|
|
||||||
|
output=$(hyprctl monitors 2>/dev/null) || {
|
||||||
|
echo "Error: hyprctl not found or command failed" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
mapfile -t monitors < <(
|
||||||
|
grep -oP '(?<=^Monitor ).*?(?= \(ID )' <<<"$output"
|
||||||
|
)
|
||||||
|
|
||||||
|
len=${#monitors[@]}
|
||||||
|
|
||||||
|
if (( len == 2 )); then
|
||||||
|
hyprctl keyword monitor $INT, disable 2>/dev/null
|
||||||
|
hyprctl keyword workspace r[0-9] m[${monitors[1]}]
|
||||||
|
elif (( len == 3 )); then
|
||||||
|
hyprctl keyword monitor $INT, disable 2>/dev/null
|
||||||
|
hyprctl keyword workspace r[1-5] m[${monitors[1]}]
|
||||||
|
hyprctl keyword workspace r[6-9] m[${monitors[2]}]
|
||||||
|
hyprctl keyword workspace r[0] m[${monitors[2]}]
|
||||||
|
else
|
||||||
|
hyprctl keyword monitor $INT, preferred,auto,1.5 2>/dev/null
|
||||||
|
hyprctl reload 2>/dev/null
|
||||||
|
fi
|
19
bin/omarchy-cmd-audio-switch
Executable file
19
bin/omarchy-cmd-audio-switch
Executable file
@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Find all the audio sinks but exit if there are none
|
||||||
|
sinks=($(wpctl status | sed -n '/Sinks:/,/Sources:/p' | grep -E '^\s*│\s+\*?\s*[0-9]+\.' | sed -E 's/^[^0-9]*([0-9]+)\..*/\1/'))
|
||||||
|
[ ${#sinks[@]} -eq 0 ] && exit 1
|
||||||
|
|
||||||
|
# Find current audio sink
|
||||||
|
current=$(wpctl status | sed -n '/Sinks:/,/Sources:/p' | grep '^\s*│\s*\*' | sed -E 's/^[^0-9]*([0-9]+)\..*/\1/')
|
||||||
|
|
||||||
|
# Find the next sink (looping around in the list)
|
||||||
|
for i in "${!sinks[@]}"; do
|
||||||
|
[ "${sinks[$i]}" = "$current" ] && next=${sinks[$(((i + 1) % ${#sinks[@]}))]}
|
||||||
|
done
|
||||||
|
next=${next:-${sinks[0]}}
|
||||||
|
|
||||||
|
# Set the next sink and ensure it's not muted
|
||||||
|
wpctl set-default "$next"
|
||||||
|
wpctl set-mute "$next" 0
|
||||||
|
|
9
bin/omarchy-cmd-close-all-windows
Executable file
9
bin/omarchy-cmd-close-all-windows
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Close all open windows
|
||||||
|
hyprctl clients -j | \
|
||||||
|
jq -r ".[].address" | \
|
||||||
|
xargs -I{} hyprctl dispatch closewindow address:{}
|
||||||
|
|
||||||
|
# Move to first workspace
|
||||||
|
hyprctl dispatch workspace 1
|
12
bin/omarchy-cmd-first-run
Executable file
12
bin/omarchy-cmd-first-run
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
FIRST_RUN_MODE=~/.local/state/omarchy/first-run.mode
|
||||||
|
|
||||||
|
if [[ -f "$FIRST_RUN_MODE" ]]; then
|
||||||
|
rm -f "$FIRST_RUN_MODE"
|
||||||
|
$OMARCHY_PATH/install/first-run/battery-monitor.sh
|
||||||
|
$OMARCHY_PATH/install/first-run/firewall.sh
|
||||||
|
sudo rm -f /etc/sudoers.d/first-run
|
||||||
|
fi
|
@ -13,7 +13,7 @@ screenrecording() {
|
|||||||
notify-send "Screen recording starting..." -t 1000
|
notify-send "Screen recording starting..." -t 1000
|
||||||
sleep 1
|
sleep 1
|
||||||
|
|
||||||
if lspci | grep -qi 'nvidia'; 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 -f "$filename" -c libx264 -p crf=23 -p preset=medium -p movflags=+faststart "$@"
|
||||||
else
|
else
|
||||||
wl-screenrec -f "$filename" --ffmpeg-encoder-options="-c:v libx264 -crf 23 -preset medium -movflags +faststart" "$@"
|
wl-screenrec -f "$filename" --ffmpeg-encoder-options="-c:v libx264 -crf 23 -preset medium -movflags +faststart" "$@"
|
||||||
|
7
bin/omarchy-cmd-screenrecord-stop
Executable file
7
bin/omarchy-cmd-screenrecord-stop
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
#!/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,20 +1,16 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if command -v tte &>/dev/null; then
|
while true; do
|
||||||
while true; do
|
|
||||||
effect=$(tte 2>&1 | grep -oP '{\K[^}]+' | tr ',' ' ' | tr ' ' '\n' | sed -n '/^beams$/,$p' | sort -u | shuf -n1)
|
effect=$(tte 2>&1 | grep -oP '{\K[^}]+' | tr ',' ' ' | tr ' ' '\n' | sed -n '/^beams$/,$p' | sort -u | shuf -n1)
|
||||||
tte -i ~/.local/share/omarchy/logo.txt \
|
tte -i ~/.config/omarchy/branding/screensaver.txt \
|
||||||
--frame-rate 240 --canvas-width 0 --canvas-height $(($(tput lines) - 2)) --anchor-canvas c --anchor-text c \
|
--frame-rate 240 --canvas-width 0 --canvas-height $(($(tput lines) - 2)) --anchor-canvas c --anchor-text c \
|
||||||
"$effect" &
|
"$effect" &
|
||||||
|
|
||||||
while pgrep tte >/dev/null; do
|
while pgrep -x tte >/dev/null; do
|
||||||
if read -n 1 -t 0.01; then
|
if read -n 1 -t 0.01; then
|
||||||
pkill tte 2>/dev/null
|
pkill -x tte 2>/dev/null
|
||||||
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
else
|
|
||||||
gum spin --title "Can't find tte. Try: pip install terminaltexteffects" -- sleep 2
|
|
||||||
fi
|
|
||||||
|
11
bin/omarchy-cmd-terminal-cwd
Executable file
11
bin/omarchy-cmd-terminal-cwd
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Go from current active terminal to its child shell process and run cwd there
|
||||||
|
terminal_pid=$(hyprctl activewindow | awk '/pid:/ {print $2}')
|
||||||
|
shell_pid=$(pgrep -P "$terminal_pid" | head -n1)
|
||||||
|
|
||||||
|
if [[ -n $shell_pid ]]; then
|
||||||
|
readlink -f "/proc/$shell_pid/cwd" 2>/dev/null
|
||||||
|
else
|
||||||
|
echo "$HOME"
|
||||||
|
fi
|
@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
sudo systemctl restart systemd-timesyncd
|
||||||
sudo tzupdate
|
sudo tzupdate
|
||||||
new_timezone=$(timedatectl show -p Timezone --value)
|
new_timezone=$(timedatectl show -p Timezone --value)
|
||||||
notify-send "Timezone has been set to $new_timezone"
|
omarchy-restart-waybar
|
||||||
|
notify-send "Time synced and timezone set to $new_timezone"
|
||||||
|
3
bin/omarchy-font-current
Executable file
3
bin/omarchy-font-current
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
grep -oP 'family\s*=\s*"\K[^"]+' ~/.config/alacritty/alacritty.toml | head -n1
|
@ -5,6 +5,16 @@ font_name="$1"
|
|||||||
if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
||||||
if fc-list | grep -iq "$font_name"; then
|
if fc-list | grep -iq "$font_name"; then
|
||||||
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
||||||
|
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/waybar/style.css
|
||||||
|
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/swayosd/style.css
|
||||||
|
xmlstarlet ed -L \
|
||||||
|
-u '//match[@target="pattern"][test/string="monospace"]/edit[@name="family"]/string' \
|
||||||
|
-v "$font_name" \
|
||||||
|
~/.config/fontconfig/fonts.conf
|
||||||
|
|
||||||
|
omarchy-restart-waybar
|
||||||
|
omarchy-restart-swayosd
|
||||||
|
omarchy-restart-walker
|
||||||
else
|
else
|
||||||
echo "Font '$font_name' not found."
|
echo "Font '$font_name' not found."
|
||||||
exit 1
|
exit 1
|
||||||
|
123
bin/omarchy-install-dev-env
Executable file
123
bin/omarchy-install-dev-env
Executable file
@ -0,0 +1,123 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
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
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
install_php() {
|
||||||
|
sudo pacman -Sy php composer php-sqlite --noconfirm
|
||||||
|
|
||||||
|
# Install Path for Composer
|
||||||
|
if [[ ":$PATH:" != *":$HOME/.config/composer/vendor/bin:"* ]]; then
|
||||||
|
echo 'export PATH="$HOME/.config/composer/vendor/bin:$PATH"' >>"$HOME/.bashrc"
|
||||||
|
source "$HOME/.bashrc"
|
||||||
|
echo "Added Composer global bin directory to PATH."
|
||||||
|
else
|
||||||
|
echo "Composer global bin directory already in PATH."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Enable some extensions
|
||||||
|
local php_ini_path="/etc/php/php.ini"
|
||||||
|
local extensions_to_enable=(
|
||||||
|
"bcmath"
|
||||||
|
"intl"
|
||||||
|
"iconv"
|
||||||
|
"openssl"
|
||||||
|
"pdo_sqlite"
|
||||||
|
"pdo_mysql"
|
||||||
|
)
|
||||||
|
|
||||||
|
for ext in "${extensions_to_enable[@]}"; do
|
||||||
|
sudo sed -i "s/^;extension=${ext}/extension=${ext}/" "$php_ini_path"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
ruby)
|
||||||
|
echo -e "Installing Ruby on Rails...\n"
|
||||||
|
mise use --global ruby@latest
|
||||||
|
mise settings add idiomatic_version_file_enable_tools ruby
|
||||||
|
mise x ruby -- gem install rails --no-document
|
||||||
|
echo -e "\nYou can now run: rails new myproject"
|
||||||
|
;;
|
||||||
|
node)
|
||||||
|
echo -e "Installing Node.js...\n"
|
||||||
|
mise use --global node@lts
|
||||||
|
;;
|
||||||
|
bun)
|
||||||
|
echo -e "Installing Bun...\n"
|
||||||
|
mise use -g bun@latest
|
||||||
|
;;
|
||||||
|
deno)
|
||||||
|
echo -e "Installing Deno...\n"
|
||||||
|
mise use -g deno@latest
|
||||||
|
;;
|
||||||
|
go)
|
||||||
|
echo -e "Installing Go...\n"
|
||||||
|
mise use --global go@latest
|
||||||
|
;;
|
||||||
|
php)
|
||||||
|
echo -e "Installing PHP...\n"
|
||||||
|
install_php
|
||||||
|
;;
|
||||||
|
laravel)
|
||||||
|
echo -e "Installing PHP and Laravel...\n"
|
||||||
|
install_php
|
||||||
|
composer global require laravel/installer
|
||||||
|
echo -e "\nYou can now run: laravel new myproject"
|
||||||
|
;;
|
||||||
|
symfony)
|
||||||
|
echo -e "Installing PHP and Symfony...\n"
|
||||||
|
install_php
|
||||||
|
yay -S symfony-cli --noconfirm
|
||||||
|
echo -e "\nYou can now run: symfony new --webapp myproject"
|
||||||
|
;;
|
||||||
|
python)
|
||||||
|
echo -e "Installing Python...\n"
|
||||||
|
mise use --global python@latest
|
||||||
|
echo -e "\nInstalling uv...\n"
|
||||||
|
curl -fsSL https://astral.sh/uv/install.sh | sh
|
||||||
|
;;
|
||||||
|
elixir)
|
||||||
|
echo -e "Installing Elixir...\n"
|
||||||
|
mise use --global erlang@latest
|
||||||
|
mise use --global elixir@latest
|
||||||
|
mise x elixir -- mix local.hex --force
|
||||||
|
;;
|
||||||
|
phoenix)
|
||||||
|
echo -e "Installing Phoenix Framework...\n"
|
||||||
|
# Ensure Erlang/Elixir first
|
||||||
|
mise use --global erlang@latest
|
||||||
|
mise use --global elixir@latest
|
||||||
|
# Hex & Rebar
|
||||||
|
mise x elixir -- mix local.hex --force
|
||||||
|
mise x elixir -- mix local.rebar --force
|
||||||
|
# Phoenix project (phx_new)
|
||||||
|
mise x elixir -- mix archive.install hex phx_new --force
|
||||||
|
echo -e "\nYou can now run: mix phx.new my_app"
|
||||||
|
;;
|
||||||
|
rust)
|
||||||
|
echo -e "Installing Rust...\n"
|
||||||
|
bash -c "$(curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs)" -- -y
|
||||||
|
;;
|
||||||
|
java)
|
||||||
|
echo -e "Installing Java...\n"
|
||||||
|
mise use --global java@latest
|
||||||
|
;;
|
||||||
|
zig)
|
||||||
|
echo -e "Installing Zig...\n"
|
||||||
|
mise use --global zig@latest
|
||||||
|
;;
|
||||||
|
ocaml)
|
||||||
|
echo -e "Installing OCaml...\n"
|
||||||
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/ocaml/opam/master/shell/install.sh)"
|
||||||
|
opam init --yes
|
||||||
|
eval "$(opam env)"
|
||||||
|
opam install ocaml-lsp-server odoc ocamlformat utop --yes
|
||||||
|
;;
|
||||||
|
dotnet)
|
||||||
|
echo -e "Installing .NET...\n"
|
||||||
|
mise use --global dotnet@latest
|
||||||
|
;;
|
||||||
|
esac
|
@ -1,8 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
options=("MySQL" "PostgreSQL" "Redis" "MongoDB" "MariaDB")
|
||||||
|
|
||||||
options=("MariaDB" "MySQL" "Redis" "PostgreSQL")
|
|
||||||
choices=$(printf "%s\n" "${options[@]}" | gum choose --no-limit --header "Select databases (space to select, return to install, esc to cancel)") || main_menu
|
choices=$(printf "%s\n" "${options[@]}" | gum choose --no-limit --header "Select databases (space to select, return to install, esc to cancel)") || main_menu
|
||||||
|
|
||||||
if [[ -n "$choices" ]]; then
|
if [[ -n "$choices" ]]; then
|
||||||
@ -12,8 +10,7 @@ if [[ -n "$choices" ]]; then
|
|||||||
PostgreSQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:5432:5432" --name=postgres16 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:16 ;;
|
PostgreSQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:5432:5432" --name=postgres16 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:16 ;;
|
||||||
MariaDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mariadb11 -e MARIADB_ROOT_PASSWORD= -e MARIADB_ALLOW_EMPTY_ROOT_PASSWORD=true mariadb:11.8 ;;
|
MariaDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mariadb11 -e MARIADB_ROOT_PASSWORD= -e MARIADB_ALLOW_EMPTY_ROOT_PASSWORD=true mariadb:11.8 ;;
|
||||||
Redis) sudo docker run -d --restart unless-stopped -p "127.0.0.1:6379:6379" --name=redis redis:7 ;;
|
Redis) sudo docker run -d --restart unless-stopped -p "127.0.0.1:6379:6379" --name=redis redis:7 ;;
|
||||||
|
MongoDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:27017:27017" --name mongodb -e MONGO_INITDB_ROOT_USERNAME=admin -e MONGO_INITDB_ROOT_PASSWORD=admin123 mongo:noble ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
@ -1,13 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
# FIXME: Should not use AUR dependencies when we can avoid it
|
||||||
|
echo "Installing all dependencies [from AUR]..."
|
||||||
echo "Installing all dependencies..."
|
|
||||||
yay -S --noconfirm --needed \
|
yay -S --noconfirm --needed \
|
||||||
dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
||||||
|
|
||||||
echo "Starting Dropbox..."
|
echo "Starting Dropbox..."
|
||||||
uwsm app -- dropbox-cli start &>/dev/null &
|
uwsm app -- dropbox-cli start &>/dev/null &
|
||||||
echo "See Dropbox icon behind hover tray in top right and right-click for setup."
|
echo "See Dropbox icon behind hover tray in top right and right-click for setup."
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
@ -1,13 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
|
||||||
|
|
||||||
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/^\s*#//}' /etc/pacman.conf
|
||||||
sudo pacman -Sy
|
sudo pacman -Sy
|
||||||
|
|
||||||
echo "Now pick dependencies matching your graphics card"
|
echo "Now pick dependencies matching your graphics card"
|
||||||
yay -S steam
|
sudo pacman -S steam
|
||||||
gtk-launch steam >/dev/null 2>&1 &
|
setsid gtk-launch steam >/dev/null 2>&1 &
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
13
bin/omarchy-install-tailscale
Executable file
13
bin/omarchy-install-tailscale
Executable file
@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
curl -fsSL https://tailscale.com/install.sh | sh
|
||||||
|
curl -fsSL https://neuralink.com/tsui/install.sh | bash
|
||||||
|
|
||||||
|
echo -e "\nStarting Tailscale..."
|
||||||
|
sudo tailscale up --accept-routes
|
||||||
|
|
||||||
|
echo -e "\nAdd tsui to sudoers..."
|
||||||
|
echo "$USER ALL=(ALL) NOPASSWD: $(which tsui)" | sudo tee /etc/sudoers.d/tsui
|
||||||
|
|
||||||
|
omarchy-tui-install "Tailscale" "sudo tsui" float https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
||||||
|
omarchy-webapp-install "Tailscale Admin Console" "https://login.tailscale.com/admin/machines" https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
3
bin/omarchy-launch-browser
Executable file
3
bin/omarchy-launch-browser
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
exec setsid uwsm app -- $(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,/usr}/share/applications/$(xdg-settings get default-web-browser) 2>/dev/null | head -1) ${args[@]} $@
|
@ -1,19 +1,26 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Exit early if we don't have the tte show
|
||||||
|
if ! command -v tte &>/dev/null; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# Exit early if screensave is already running
|
# Exit early if screensave is already running
|
||||||
pgrep -f "alacritty --class Screensaver" && exit 0
|
pgrep -f "alacritty --class Screensaver" && exit 0
|
||||||
|
|
||||||
|
# Allow screensaver to be turned off but also force started
|
||||||
|
if [[ -f ~/.local/state/omarchy/toggles/screensaver-off ]] && [[ $1 != "force" ]]; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
focused=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')
|
focused=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')
|
||||||
|
|
||||||
for m in $(hyprctl monitors -j | jq -r '.[] | .name'); do
|
for m in $(hyprctl monitors -j | jq -r '.[] | .name'); do
|
||||||
hyprctl dispatch focusmonitor $m
|
hyprctl dispatch focusmonitor $m
|
||||||
hyprctl dispatch exec -- \
|
hyprctl dispatch exec -- \
|
||||||
alacritty --class Screensaver \
|
alacritty --class Screensaver \
|
||||||
-o 'colors.primary.background="#000000"' \
|
--config-file ~/.local/share/omarchy/default/alacritty/screensaver.toml \
|
||||||
-o 'colors.cursor.cursor="#000000"' \
|
-e omarchy-cmd-screensaver
|
||||||
-o 'font.size=18' \
|
|
||||||
-o 'window.opacity=1' \
|
|
||||||
-e ~/.local/share/omarchy/bin/omarchy-cmd-screensaver
|
|
||||||
done
|
done
|
||||||
|
|
||||||
hyprctl dispatch focusmonitor $focused
|
hyprctl dispatch focusmonitor $focused
|
||||||
|
10
bin/omarchy-launch-webapp
Executable file
10
bin/omarchy-launch-webapp
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
browser=$(xdg-settings get default-web-browser)
|
||||||
|
|
||||||
|
case $browser in
|
||||||
|
google-chrome* | brave-browser* | microsoft-edge* | opera* | vivaldi*) ;;
|
||||||
|
*) browser="chromium.desktop" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
exec setsid uwsm app -- $(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,/usr}/share/applications/$browser 2>/dev/null | head -1) --app="$1" "${@:2}"
|
12
bin/omarchy-lock-screen
Executable file
12
bin/omarchy-lock-screen
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Lock the screen
|
||||||
|
pidof hyprlock || hyprlock &
|
||||||
|
|
||||||
|
# Ensure 1password is locked
|
||||||
|
if pgrep -x "1password" >/dev/null; then
|
||||||
|
1password --lock &
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Avoid running screensaver when locked
|
||||||
|
pkill -f "alacritty --class Screensaver"
|
298
bin/omarchy-menu
298
bin/omarchy-menu
@ -1,17 +1,32 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
OMARCHY_BIN_PATH=~/.local/share/omarchy/bin
|
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
||||||
|
|
||||||
menu() {
|
menu() {
|
||||||
echo -e "$2" | walker --dmenu --theme dmenu_250 -p "$1…" $3
|
local prompt="$1"
|
||||||
|
local options="$2"
|
||||||
|
local extra="$3"
|
||||||
|
local preselect="$4"
|
||||||
|
|
||||||
|
read -r -a args <<<"$extra"
|
||||||
|
|
||||||
|
if [[ -n "$preselect" ]]; then
|
||||||
|
local index
|
||||||
|
index=$(echo -e "$options" | grep -nxF "$preselect" | cut -d: -f1)
|
||||||
|
if [[ -n "$index" ]]; then
|
||||||
|
args+=("-a" "$index")
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -e "$options" | walker --dmenu --theme dmenu_250 -p "$prompt…" "${args[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
terminal() {
|
terminal() {
|
||||||
alacritty --class Omarchy -e $1
|
alacritty --class Omarchy -e "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
present_terminal() {
|
present_terminal() {
|
||||||
alacritty --class Omarchy -e bash -c "~/.local/share/omarchy/bin/omarchy-show-logo; eval \"$1\"; ~/.local/share/omarchy/bin/omarchy-show-done;"
|
alacritty --class Omarchy -e bash -c "omarchy-show-logo; eval \"$1\"; omarchy-show-done;"
|
||||||
}
|
}
|
||||||
|
|
||||||
edit_in_nvim() {
|
edit_in_nvim() {
|
||||||
@ -19,50 +34,64 @@ edit_in_nvim() {
|
|||||||
alacritty -e nvim "$1"
|
alacritty -e nvim "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
install() {
|
||||||
|
present_terminal "echo 'Installing $1...'; sudo pacman -Sy --noconfirm $2"
|
||||||
|
}
|
||||||
|
|
||||||
install_and_launch() {
|
install_and_launch() {
|
||||||
present_terminal "echo 'Installing $1...'; yay -Sy --noconfirm $2 && gtk-launch $3"
|
present_terminal "echo 'Installing $1...'; sudo pacman -Sy --noconfirm $2 && setsid gtk-launch $3"
|
||||||
}
|
}
|
||||||
|
|
||||||
install_font() {
|
install_font() {
|
||||||
present_terminal "echo 'Installing $1...'; yay -Sy --noconfirm --needed $2 && sleep 2 && ~/.local/share/omarchy/bin/omarchy-font-set '$3'"
|
present_terminal "echo 'Installing $1...'; sudo pacman -Sy --noconfirm --needed $2 && sleep 2 && omarchy-font-set '$3'"
|
||||||
|
}
|
||||||
|
|
||||||
|
aur_install() {
|
||||||
|
present_terminal "echo 'Installing $1 from AUR...'; yay -Sy --noconfirm $2"
|
||||||
|
}
|
||||||
|
|
||||||
|
aur_install_and_launch() {
|
||||||
|
present_terminal "echo 'Installing $1 from AUR...'; yay -Sy --noconfirm $2 && setsid gtk-launch $3"
|
||||||
}
|
}
|
||||||
|
|
||||||
show_learn_menu() {
|
show_learn_menu() {
|
||||||
case $(menu "Learn" " Keybindings\n Omarchy\n Hyprland\n Arch\n Neovim\n Bash") in
|
case $(menu "Learn" " Keybindings\n Omarchy\n Hyprland\n Arch\n Neovim\n Bash") in
|
||||||
*Keybindings*) $OMARCHY_BIN_PATH/omarchy-menu-keybindings ;;
|
*Keybindings*) omarchy-menu-keybindings ;;
|
||||||
*Omarchy*) setsid chromium --new-window --app="https://manuals.omamix.org/2/the-omarchy-manual" & ;;
|
*Omarchy*) omarchy-launch-webapp "https://learn.omacom.io/2/the-omarchy-manual" ;;
|
||||||
*Hyprland*) setsid chromium --new-window --app="https://wiki.hypr.land/" & ;;
|
*Hyprland*) omarchy-launch-webapp "https://wiki.hypr.land/" ;;
|
||||||
*Arch*) setsid chromium --new-window --app="https://wiki.archlinux.org/title/Main_page" & ;;
|
*Arch*) omarchy-launch-webapp "https://wiki.archlinux.org/title/Main_page" ;;
|
||||||
*Bash*) setsid chromium --new-window --app="https://devhints.io/bash" & ;;
|
*Bash*) omarchy-launch-webapp "https://devhints.io/bash" ;;
|
||||||
*Neovim*) setsid chromium --new-window --app="https://www.lazyvim.org/keymaps" & ;;
|
*Neovim*) omarchy-launch-webapp "https://www.lazyvim.org/keymaps" ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_style_menu() {
|
show_style_menu() {
|
||||||
case $(menu "Style" " Theme\n Font\n Background") in
|
case $(menu "Style" " Theme\n Font\n Background\n Screensaver\n About") in
|
||||||
*Theme*) show_theme_menu ;;
|
*Theme*) show_theme_menu ;;
|
||||||
*Font*) show_font_menu ;;
|
*Font*) show_font_menu ;;
|
||||||
*Background*) $OMARCHY_BIN_PATH/omarchy-theme-bg-next ;;
|
*Background*) omarchy-theme-bg-next ;;
|
||||||
|
*Screensaver*) edit_in_nvim ~/.config/omarchy/branding/screensaver.txt ;;
|
||||||
|
*About*) edit_in_nvim ~/.config/omarchy/branding/about.txt ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_theme_menu() {
|
show_theme_menu() {
|
||||||
theme=$(menu "Theme" "$($OMARCHY_BIN_PATH/omarchy-theme-list)")
|
theme=$(menu "Theme" "$(omarchy-theme-list)" "" "$(omarchy-theme-current)")
|
||||||
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
||||||
show_main_menu
|
show_main_menu
|
||||||
else
|
else
|
||||||
$OMARCHY_BIN_PATH/omarchy-theme-set "$theme"
|
omarchy-theme-set "$theme"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
show_font_menu() {
|
show_font_menu() {
|
||||||
theme=$(menu "Font" "$($OMARCHY_BIN_PATH/omarchy-font-list)" "-w 350")
|
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
|
show_main_menu
|
||||||
else
|
else
|
||||||
$OMARCHY_BIN_PATH/omarchy-font-set "$theme"
|
omarchy-font-set "$theme"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,85 +106,144 @@ show_capture_menu() {
|
|||||||
|
|
||||||
show_screenshot_menu() {
|
show_screenshot_menu() {
|
||||||
case $(menu "Screenshot" " Region\n Window\n Display") in
|
case $(menu "Screenshot" " Region\n Window\n Display") in
|
||||||
*Region*) $OMARCHY_BIN_PATH/omarchy-cmd-screenshot ;;
|
*Region*) omarchy-cmd-screenshot ;;
|
||||||
*Window*) $OMARCHY_BIN_PATH/omarchy-cmd-screenshot window ;;
|
*Window*) omarchy-cmd-screenshot window ;;
|
||||||
*Display*) $OMARCHY_BIN_PATH/omarchy-cmd-screenshot output ;;
|
*Display*) omarchy-cmd-screenshot output ;;
|
||||||
*) show_capture_menu ;;
|
*) show_capture_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_screenrecord_menu() {
|
show_screenrecord_menu() {
|
||||||
case $(menu "Screenrecord" " Region\n Display") in
|
case $(menu "Screenrecord" " Region\n Display") in
|
||||||
*Region*) $OMARCHY_BIN_PATH/omarchy-cmd-screenrecord ;;
|
*Region*) omarchy-cmd-screenrecord ;;
|
||||||
*Display*) $OMARCHY_BIN_PATH/omarchy-cmd-screenrecord output ;;
|
*Display*) omarchy-cmd-screenrecord output ;;
|
||||||
*) show_capture_menu ;;
|
*) show_capture_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_toggle_menu() {
|
show_toggle_menu() {
|
||||||
case $(menu "Toggle" " Screensaver\n Nightlight\n Idle Lock\n Top Bar") in
|
case $(menu "Toggle" " Screensaver\n Nightlight\n Idle Lock\n Top Bar") in
|
||||||
*Screensaver*) $OMARCHY_BIN_PATH/omarchy-launch-screensaver ;;
|
*Screensaver*) omarchy-toggle-screensaver ;;
|
||||||
*Nightlight*) $OMARCHY_BIN_PATH/omarchy-toggle-nightlight ;;
|
*Nightlight*) omarchy-toggle-nightlight ;;
|
||||||
*Idle*) $OMARCHY_BIN_PATH/omarchy-toggle-idle ;;
|
*Idle*) omarchy-toggle-idle ;;
|
||||||
*Bar*) pkill -SIGUSR1 waybar ;;
|
*Bar*) omarchy-toggle-waybar ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_setup_menu() {
|
show_setup_menu() {
|
||||||
local options=" Audio\n Wifi\n Bluetooth\n Monitors"
|
local options=" Audio\n Wifi\n Bluetooth\n Power Profile\n Monitors"
|
||||||
[ -f ~/.config/hypr/bindings.conf ] && options="$options\n Keybindings"
|
[ -f ~/.config/hypr/bindings.conf ] && options="$options\n Keybindings"
|
||||||
[ -f ~/.config/hypr/input.conf ] && options="$options\n Input"
|
[ -f ~/.config/hypr/input.conf ] && options="$options\n Input"
|
||||||
options="$options\n Configs\n Fingerprint\n Fido2"
|
options="$options\n DNS\n Config\n Fingerprint\n Fido2"
|
||||||
|
|
||||||
case $(menu "Setup" "$options") in
|
case $(menu "Setup" "$options") in
|
||||||
*Audio*) alacritty --class=Wiremix -e wiremix ;;
|
*Audio*) alacritty --class=Wiremix -e wiremix ;;
|
||||||
*Wifi*) alacritty --class=Impala -e impala ;;
|
*Wifi*)
|
||||||
*Bluetooth*) blueberry ;;
|
rfkill unblock wifi
|
||||||
|
alacritty --class=Impala -e impala
|
||||||
|
;;
|
||||||
|
*Bluetooth*)
|
||||||
|
rfkill unblock bluetooth
|
||||||
|
blueberry
|
||||||
|
;;
|
||||||
|
*Power*) show_setup_power_menu ;;
|
||||||
*Monitors*) edit_in_nvim ~/.config/hypr/monitors.conf ;;
|
*Monitors*) edit_in_nvim ~/.config/hypr/monitors.conf ;;
|
||||||
*Keybindings*) edit_in_nvim ~/.config/hypr/bindings.conf ;;
|
*Keybindings*) edit_in_nvim ~/.config/hypr/bindings.conf ;;
|
||||||
*Input*) edit_in_nvim ~/.config/hypr/input.conf ;;
|
*Input*) edit_in_nvim ~/.config/hypr/input.conf ;;
|
||||||
*Configs*) show_setup_configs_menu ;;
|
*DNS*) present_terminal omarchy-setup-dns ;;
|
||||||
*Fingerprint*) terminal $OMARCHY_BIN_PATH/omarchy-setup-fingerprint ;;
|
*Config*) show_setup_config_menu ;;
|
||||||
*Fido2*) terminal $OMARCHY_BIN_PATH/omarchy-setup-fido2 ;;
|
*Fingerprint*) present_terminal omarchy-setup-fingerprint ;;
|
||||||
|
*Fido2*) present_terminal omarchy-setup-fido2 ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_setup_configs_menu() {
|
show_setup_power_menu() {
|
||||||
|
profile=$(menu "Power Profile" "$(omarchy-powerprofiles-list)" "" "$(powerprofilesctl get)")
|
||||||
|
|
||||||
|
if [[ "$profile" == "CNCLD" || -z "$profile" ]]; then
|
||||||
|
show_main_menu
|
||||||
|
else
|
||||||
|
powerprofilesctl set "$profile"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
show_setup_config_menu() {
|
||||||
case $(menu "Setup" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Swayosd\n Walker\n Waybar\n XCompose") in
|
case $(menu "Setup" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Swayosd\n Walker\n Waybar\n XCompose") in
|
||||||
*Hyprland*) edit_in_nvim ~/.config/hypr/hyprland.conf ;;
|
*Hyprland*) edit_in_nvim ~/.config/hypr/hyprland.conf ;;
|
||||||
*Hypridle*) edit_in_nvim ~/.config/hypr/hypridle.conf && ~/.local/share/omarchy/bin/omarchy-restart-hypridle ;;
|
*Hypridle*) edit_in_nvim ~/.config/hypr/hypridle.conf && omarchy-restart-hypridle ;;
|
||||||
*Hyprlock*) edit_in_nvim ~/.config/hypr/hyprlock.conf ;;
|
*Hyprlock*) edit_in_nvim ~/.config/hypr/hyprlock.conf ;;
|
||||||
*Hyprsunset*) edit_in_nvim ~/.config/hypr/hyprsunset.conf && ~/.local/share/omarchy/bin/omarchy-restart-hyprsunset ;;
|
*Hyprsunset*) edit_in_nvim ~/.config/hypr/hyprsunset.conf && omarchy-restart-hyprsunset ;;
|
||||||
*Swayosd*) edit_in_nvim ~/.config/swayosd/config.toml && ~/.local/share/omarchy/bin/omarchy-restart-swayosd ;;
|
*Swayosd*) edit_in_nvim ~/.config/swayosd/config.toml && omarchy-restart-swayosd ;;
|
||||||
*Walker*) edit_in_nvim ~/.config/walker/config.toml && ~/.local/share/omarchy/bin/omarchy-restart-walker ;;
|
*Walker*) edit_in_nvim ~/.config/walker/config.toml && omarchy-restart-walker ;;
|
||||||
*Waybar*) edit_in_nvim ~/.config/waybar/config.jsonc && ~/.local/share/omarchy/bin/omarchy-restart-waybar ;;
|
*Waybar*) edit_in_nvim ~/.config/waybar/config.jsonc && omarchy-restart-waybar ;;
|
||||||
*XCompose*) edit_in_nvim ~/.XCompose && ~/.local/share/omarchy/bin/omarchy-restart-xcompose ;;
|
*XCompose*) edit_in_nvim ~/.XCompose && omarchy-restart-xcompose ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_menu() {
|
show_install_menu() {
|
||||||
case $(menu "Install" " Package\n Web App\n Editor\n Theme\n Background\n Font\n Dropbox\n Steam\n Docker DBs") in
|
case $(menu "Install" " Package\n AUR\n Web App\n TUI\n Service\n Style\n Development\n Editor\n AI\n Gaming") in
|
||||||
*Package*) terminal $OMARCHY_BIN_PATH/omarchy-pkg-install ;;
|
*Package*) terminal omarchy-pkg-install ;;
|
||||||
*Web*) terminal $OMARCHY_BIN_PATH/omarchy-webapp-install ;;
|
*AUR*) terminal omarchy-pkg-aur-install ;;
|
||||||
|
*Web*) present_terminal omarchy-webapp-install ;;
|
||||||
|
*TUI*) present_terminal omarchy-tui-install ;;
|
||||||
|
*Service*) show_install_service_menu ;;
|
||||||
|
*Style*) show_install_style_menu ;;
|
||||||
|
*Development*) show_install_development_menu ;;
|
||||||
*Editor*) show_install_editor_menu ;;
|
*Editor*) show_install_editor_menu ;;
|
||||||
*Theme*) terminal $OMARCHY_BIN_PATH/omarchy-theme-install ;;
|
*AI*) show_install_ai_menu ;;
|
||||||
*Background*) nautilus ~/.config/omarchy/current/theme/backgrounds ;;
|
*Gaming*) show_install_gaming_menu ;;
|
||||||
*Font*) show_install_font_menu ;;
|
|
||||||
*Dropbox*) terminal $OMARCHY_BIN_PATH/omarchy-setup-dropbox ;;
|
|
||||||
*Steam*) terminal $OMARCHY_BIN_PATH/omarchy-setup-steam ;;
|
|
||||||
*Docker*) terminal $OMARCHY_BIN_PATH/omarchy-setup-docker-dbs ;;
|
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_install_service_menu() {
|
||||||
|
case $(menu "Install" " Dropbox\n Tailscale") in
|
||||||
|
*Dropbox*) present_terminal omarchy-install-dropbox ;;
|
||||||
|
*Tailscale*) present_terminal omarchy-install-tailscale ;;
|
||||||
|
*) show_install_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
show_install_editor_menu() {
|
show_install_editor_menu() {
|
||||||
case $(menu "Install" " VSCode\n Cursor\n Zed") in
|
case $(menu "Install" " VSCode\n Cursor [AUR]\n Zed\n Sublime Text\n Helix") in
|
||||||
*VSCode*) install_and_launch "VSCode" "visual-studio-code-bin" "code" ;;
|
*VSCode*) install_and_launch "VSCode" "visual-studio-code-bin" "code" ;;
|
||||||
*Cursor*) install_and_launch "Cursor" "cursor-bin" "cursor-cursor" ;;
|
*Cursor*) aur_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" ;;
|
||||||
|
*Helix*) install "Helix" "helix" ;;
|
||||||
|
*) show_install_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
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
|
||||||
|
*Claude*) aur_install "Claude Code" "claude-code" ;;
|
||||||
|
*Gemini*) install "Gemini" "gemini-cli" ;;
|
||||||
|
*Studio*) aur_install "LM Studio" "lmstudio" ;;
|
||||||
|
*Ollama*) install "Ollama" "ollama" ;;
|
||||||
|
*Crush*) aur_install "Crush" "crush-bin" ;;
|
||||||
|
*opencode*) aur_install "opencode" "opencode-bin" ;;
|
||||||
|
*) show_install_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_install_gaming_menu() {
|
||||||
|
case $(menu "Install" " Steam\n RetroArch [AUR]\n Minecraft") in
|
||||||
|
*Steam*) present_terminal omarchy-install-steam ;;
|
||||||
|
*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" ;;
|
||||||
|
*) show_install_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_install_style_menu() {
|
||||||
|
case $(menu "Install" " Theme\n Background\n Font") in
|
||||||
|
*Theme*) present_terminal omarchy-theme-install ;;
|
||||||
|
*Background*) nautilus ~/.config/omarchy/current/theme/backgrounds ;;
|
||||||
|
*Font*) show_install_font_menu ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@ -170,44 +258,102 @@ show_install_font_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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
|
||||||
|
*Rails*) present_terminal "omarchy-install-dev-env ruby" ;;
|
||||||
|
*Docker*) present_terminal omarchy-install-docker-dbs ;;
|
||||||
|
*JavaScript*) show_install_javascript_menu ;;
|
||||||
|
*Go*) present_terminal "omarchy-install-dev-env go" ;;
|
||||||
|
*PHP*) show_install_php_menu ;;
|
||||||
|
*Python*) present_terminal "omarchy-install-dev-env python" ;;
|
||||||
|
*Elixir*) show_install_elixir_menu ;;
|
||||||
|
*Zig*) present_terminal "omarchy-install-dev-env zig" ;;
|
||||||
|
*Rust*) present_terminal "omarchy-install-dev-env rust" ;;
|
||||||
|
*Java*) present_terminal "omarchy-install-dev-env java" ;;
|
||||||
|
*NET*) present_terminal "omarchy-install-dev-env dotnet" ;;
|
||||||
|
*OCaml*) present_terminal "omarchy-install-dev-env ocaml" ;;
|
||||||
|
*) show_install_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_install_javascript_menu() {
|
||||||
|
case $(menu "Install" " Node.js\n Bun\n Deno") in
|
||||||
|
*Node*) present_terminal "omarchy-install-dev-env node" ;;
|
||||||
|
*Bun*) present_terminal "omarchy-install-dev-env bun" ;;
|
||||||
|
*Deno*) present_terminal "omarchy-install-dev-env deno" ;;
|
||||||
|
*) show_install_development_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_install_php_menu() {
|
||||||
|
case $(menu "Install" " PHP\n Laravel\n Symfony") in
|
||||||
|
*PHP*) present_terminal "omarchy-install-dev-env php" ;;
|
||||||
|
*Laravel*) present_terminal "omarchy-install-dev-env laravel" ;;
|
||||||
|
*Symfony*) present_terminal "omarchy-install-dev-env symfony" ;;
|
||||||
|
*) show_install_development_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_install_elixir_menu() {
|
||||||
|
case $(menu "Install" " Elixir\n Phoenix") in
|
||||||
|
*Elixir*) present_terminal "omarchy-install-dev-env elixir" ;;
|
||||||
|
*Phoenix*) present_terminal "omarchy-install-dev-env phoenix" ;;
|
||||||
|
*) show_install_development_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
show_remove_menu() {
|
show_remove_menu() {
|
||||||
case $(menu "Remove" " Package\n Web App\n Theme\n Fingerprint\n Fido2") in
|
case $(menu "Remove" " Package\n Web App\n TUI\n Theme\n Fingerprint\n Fido2") in
|
||||||
*Package*) terminal $OMARCHY_BIN_PATH/omarchy-pkg-remove ;;
|
*Package*) terminal omarchy-pkg-remove ;;
|
||||||
*Web*) terminal $OMARCHY_BIN_PATH/omarchy-webapp-remove ;;
|
*Web*) present_terminal omarchy-webapp-remove ;;
|
||||||
*Theme*) present_terminal $OMARCHY_BIN_PATH/omarchy-theme-remove ;;
|
*TUI*) present_terminal omarchy-tui-remove ;;
|
||||||
*Fingerprint*) terminal "$OMARCHY_BIN_PATH/omarchy-setup-fingerprint --remove" ;;
|
*Theme*) present_terminal omarchy-theme-remove ;;
|
||||||
*Fido2*) terminal "$OMARCHY_BIN_PATH/omarchy-setup-fido2 --remove" ;;
|
*Fingerprint*) present_terminal "omarchy-setup-fingerprint --remove" ;;
|
||||||
|
*Fido2*) present_terminal "omarchy-setup-fido2 --remove" ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_update_menu() {
|
show_update_menu() {
|
||||||
case $(menu "Update" " Omarchy\n Configs\n Themes\n Timezone") in
|
case $(menu "Update" " Omarchy\n Config\n Themes\n Process\n Timezone") in
|
||||||
*Omarchy*) terminal $OMARCHY_BIN_PATH/omarchy-update ;;
|
*Omarchy*) present_terminal omarchy-update ;;
|
||||||
*Configs*) show_update_configs_menu ;;
|
*Config*) show_update_config_menu ;;
|
||||||
*Themes*) terminal $OMARCHY_BIN_PATH/omarchy-theme-update ;;
|
*Themes*) present_terminal omarchy-theme-update ;;
|
||||||
*Timezone*) $OMARCHY_BIN_PATH/omarchy-cmd-tzupdate ;;
|
*Process*) show_update_process_menu ;;
|
||||||
|
*Timezone*) omarchy-cmd-tzupdate ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_update_configs_menu() {
|
show_update_process_menu() {
|
||||||
|
case $(menu "Restart" " Hypridle\n Hyprsunset\n Swayosd\n Walker\n Waybar") in
|
||||||
|
*Hypridle*) omarchy-restart-hypridle ;;
|
||||||
|
*Hyprsunset*) omarchy-restart-hyprsunset ;;
|
||||||
|
*Swayosd*) omarchy-restart-swayosd ;;
|
||||||
|
*Walker*) omarchy-restart-walker ;;
|
||||||
|
*Waybar*) omarchy-restart-waybar ;;
|
||||||
|
*) show_main_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_update_config_menu() {
|
||||||
case $(menu "Use default config" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Plymouth\n Swayosd\n Walker\n Waybar") in
|
case $(menu "Use default config" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Plymouth\n Swayosd\n Walker\n Waybar") in
|
||||||
*Hyprland*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-hyprland ;;
|
*Hyprland*) present_terminal omarchy-refresh-hyprland ;;
|
||||||
*Hypridle*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-hypridle ;;
|
*Hypridle*) present_terminal omarchy-refresh-hypridle ;;
|
||||||
*Hyprlock*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-hyprlock ;;
|
*Hyprlock*) present_terminal omarchy-refresh-hyprlock ;;
|
||||||
*Hyprsunset*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-hyprsunset ;;
|
*Hyprsunset*) present_terminal omarchy-refresh-hyprsunset ;;
|
||||||
*Plymouth*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-plymouth ;;
|
*Plymouth*) present_terminal omarchy-refresh-plymouth ;;
|
||||||
*Swayosd*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-swayosd ;;
|
*Swayosd*) present_terminal omarchy-refresh-swayosd ;;
|
||||||
*Walker*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-walker ;;
|
*Walker*) present_terminal omarchy-refresh-walker ;;
|
||||||
*Waybar*) present_terminal $OMARCHY_BIN_PATH/omarchy-refresh-waybar ;;
|
*Waybar*) present_terminal omarchy-refresh-waybar ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_system_menu() {
|
show_system_menu() {
|
||||||
case $(menu "System" " Lock\n Suspend\n Relaunch\n Restart\n Shutdown") in
|
case $(menu "System" " Lock\n Screensaver\n Suspend\n Relaunch\n Restart\n Shutdown") in
|
||||||
*Lock*) hyprlock ;;
|
*Lock*) omarchy-lock-screen ;;
|
||||||
|
*Screensaver*) omarchy-launch-screensaver force ;;
|
||||||
*Suspend*) systemctl suspend ;;
|
*Suspend*) systemctl suspend ;;
|
||||||
*Relaunch*) uwsm stop ;;
|
*Relaunch*) uwsm stop ;;
|
||||||
*Restart*) systemctl reboot ;;
|
*Restart*) systemctl reboot ;;
|
||||||
@ -217,7 +363,7 @@ show_system_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_main_menu() {
|
show_main_menu() {
|
||||||
go_to_menu "$(menu "Start" " Apps\n Learning\n Capture\n Toggle\n Style\n Setup\n Install\n Remove\n Update\n About\n System")"
|
go_to_menu "$(menu "Go" " Apps\n Learn\n Capture\n Toggle\n Style\n Setup\n Install\n Remove\n Update\n About\n System")"
|
||||||
}
|
}
|
||||||
|
|
||||||
go_to_menu() {
|
go_to_menu() {
|
||||||
@ -235,7 +381,7 @@ go_to_menu() {
|
|||||||
*remove*) show_remove_menu ;;
|
*remove*) show_remove_menu ;;
|
||||||
*update*) show_update_menu ;;
|
*update*) show_update_menu ;;
|
||||||
*system*) show_system_menu ;;
|
*system*) show_system_menu ;;
|
||||||
*about*) gtk-launch About.desktop ;;
|
*about*) terminal bash -c 'fastfetch; read -n 1 -s' ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,7 +31,10 @@ dynamic_bindings() {
|
|||||||
-e 's/^65,/SUPER SHIFT,/' \
|
-e 's/^65,/SUPER SHIFT,/' \
|
||||||
-e 's/^68,/SUPER CTRL,/' \
|
-e 's/^68,/SUPER CTRL,/' \
|
||||||
-e 's/^69,/SUPER SHIFT CTRL,/' \
|
-e 's/^69,/SUPER SHIFT CTRL,/' \
|
||||||
-e 's/^72,/SUPER ALT,/'
|
-e 's/^72,/SUPER ALT,/' \
|
||||||
|
-e 's/^73,/SUPER SHIFT ALT,/' \
|
||||||
|
-e 's/^76,/SUPER CTRL ALT,/' \
|
||||||
|
-e 's/^77,/SUPER SHIFT CTRL ALT,/'
|
||||||
}
|
}
|
||||||
|
|
||||||
# Parse and format keybindings
|
# Parse and format keybindings
|
||||||
|
4
bin/omarchy-pkg-aur-accessible
Executable file
4
bin/omarchy-pkg-aur-accessible
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
curl -sf --connect-timeout 30 --retry 3 --retry-delay 3 -A "omarchy-update" \
|
||||||
|
"https://aur.archlinux.org/rpc/?v=5&type=info&arg=base" >/dev/null
|
24
bin/omarchy-pkg-aur-install
Executable file
24
bin/omarchy-pkg-aur-install
Executable file
@ -0,0 +1,24 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
fzf_args=(
|
||||||
|
--multi
|
||||||
|
--preview 'yay -Sii {1}'
|
||||||
|
--preview-label='alt-p: toggle description, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
||||||
|
--preview-label-pos='bottom'
|
||||||
|
--preview-window 'down:65%:wrap'
|
||||||
|
--bind 'alt-p:toggle-preview'
|
||||||
|
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
||||||
|
--bind 'alt-k:preview-up,alt-j:preview-down'
|
||||||
|
--color 'pointer:green,marker:green'
|
||||||
|
)
|
||||||
|
|
||||||
|
pkg_names=$(yay -Slqa | fzf "${fzf_args[@]}")
|
||||||
|
|
||||||
|
if [[ -n "$pkg_names" ]]; then
|
||||||
|
# Convert newline-separated selections to space-separated for yay
|
||||||
|
echo "$pkg_names" | tr '\n' ' ' | xargs yay -Sy --noconfirm
|
||||||
|
sudo updatedb
|
||||||
|
omarchy-show-done
|
||||||
|
fi
|
@ -1,9 +1,25 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
pkg_name=$(yay -Slq | fzf --multi --preview 'yay -Sii {1}' --preview-window=down:75%)
|
set -e
|
||||||
|
|
||||||
if [[ -n "$pkg_name" ]]; then
|
fzf_args=(
|
||||||
yay -Sy --noconfirm "$pkg_name"
|
--multi
|
||||||
|
--preview 'pacman -Sii {1}'
|
||||||
|
--preview-label='alt-p: toggle description, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
||||||
|
--preview-label-pos='bottom'
|
||||||
|
--preview-window 'down:65%:wrap'
|
||||||
|
--bind 'alt-p:toggle-preview'
|
||||||
|
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
||||||
|
--bind 'alt-k:preview-up,alt-j:preview-down'
|
||||||
|
--color 'pointer:green,marker:green'
|
||||||
|
)
|
||||||
|
|
||||||
|
sudo pacman -Sy
|
||||||
|
pkg_names=$(pacman -Slq | fzf "${fzf_args[@]}")
|
||||||
|
|
||||||
|
if [[ -n "$pkg_names" ]]; then
|
||||||
|
# Convert newline-separated selections to space-separated for yay
|
||||||
|
echo "$pkg_names" | tr '\n' ' ' | xargs sudo pacman -Sy --noconfirm
|
||||||
sudo updatedb
|
sudo updatedb
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
@ -1,9 +1,22 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
pkg_name=$(yay -Qqe | fzf --multi --preview 'yay -Qi {1}' --preview-window=down:75%)
|
fzf_args=(
|
||||||
|
--multi
|
||||||
|
--preview 'yay -Qi {1}'
|
||||||
|
--preview-label='alt-p: toggle description, alt-j/k: scroll, tab: multi-select, F11: maximize'
|
||||||
|
--preview-label-pos='bottom'
|
||||||
|
--preview-window 'down:65%:wrap'
|
||||||
|
--bind 'alt-p:toggle-preview'
|
||||||
|
--bind 'alt-d:preview-half-page-down,alt-u:preview-half-page-up'
|
||||||
|
--bind 'alt-k:preview-up,alt-j:preview-down'
|
||||||
|
--color 'pointer:red,marker:red'
|
||||||
|
)
|
||||||
|
|
||||||
if [[ -n "$pkg_name" ]]; then
|
pkg_names=$(yay -Qqe | fzf "${fzf_args[@]}")
|
||||||
yay -Rns --noconfirm "$pkg_name"
|
|
||||||
|
if [[ -n "$pkg_names" ]]; then
|
||||||
|
# Convert newline-separated selections to space-separated for yay
|
||||||
|
echo "$pkg_names" | tr '\n' ' ' | xargs sudo pacman -Rns --noconfirm
|
||||||
sudo updatedb
|
sudo updatedb
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
omarchy-show-done
|
||||||
fi
|
fi
|
||||||
|
5
bin/omarchy-powerprofiles-list
Executable file
5
bin/omarchy-powerprofiles-list
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
powerprofilesctl list |
|
||||||
|
awk '/^\s*[* ]\s*[a-zA-Z0-9\-]+:$/ { gsub(/^[*[:space:]]+|:$/,""); print }' |
|
||||||
|
tac
|
@ -10,9 +10,4 @@ mkdir -p ~/.local/share/applications
|
|||||||
cp ~/.local/share/omarchy/applications/*.desktop ~/.local/share/applications/
|
cp ~/.local/share/omarchy/applications/*.desktop ~/.local/share/applications/
|
||||||
cp ~/.local/share/omarchy/applications/hidden/*.desktop ~/.local/share/applications/
|
cp ~/.local/share/omarchy/applications/hidden/*.desktop ~/.local/share/applications/
|
||||||
|
|
||||||
# Only copy xtras if user is not in bare mode
|
|
||||||
if [[ ! -f ~/.local/state/omarchy/bare.mode ]] && [ -z "$OMARCHY_BARE" ]; then
|
|
||||||
cp ~/.local/share/omarchy/applications/xtras/*.desktop ~/.local/share/applications/
|
|
||||||
fi
|
|
||||||
|
|
||||||
update-desktop-database ~/.local/share/applications
|
update-desktop-database ~/.local/share/applications
|
||||||
|
@ -32,7 +32,7 @@ if [[ -f "$user_config_file" ]]; then
|
|||||||
rm "$backup_config_file"
|
rm "$backup_config_file"
|
||||||
else
|
else
|
||||||
echo -e "\e[31mReplaced $user_config_file with new Omarchy default.\nSaved backup as ${backup_config_file}.\n\n\e[32mChanges:\e[0m"
|
echo -e "\e[31mReplaced $user_config_file with new Omarchy default.\nSaved backup as ${backup_config_file}.\n\n\e[32mChanges:\e[0m"
|
||||||
diff "$user_config_file" "$backup_config_file"
|
diff "$user_config_file" "$backup_config_file" || true
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
# Config file did not exist already
|
# Config file did not exist already
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/hypridle.conf
|
omarchy-refresh-config hypr/hypridle.conf
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-hypridle
|
omarchy-restart-hypridle
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/autostart.conf
|
omarchy-refresh-config hypr/autostart.conf
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/bindings.conf
|
omarchy-refresh-config hypr/bindings.conf
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/envs.conf
|
omarchy-refresh-config hypr/envs.conf
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/input.conf
|
omarchy-refresh-config hypr/input.conf
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/hyprland.conf
|
omarchy-refresh-config hypr/hyprland.conf
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/hyprlock.conf
|
omarchy-refresh-config hypr/hyprlock.conf
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config hypr/hyprsunset.conf
|
omarchy-refresh-config hypr/hyprsunset.conf
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-hyprsunset
|
omarchy-restart-hyprsunset
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [[ "$1" == "-y" ]] || gum confirm "Refresh Plymouth theme? This will replace your current startup screen with Omarchy defaults."; then
|
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 -R omarchy
|
sudo plymouth-set-default-theme -R omarchy
|
||||||
fi
|
fi
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config swayosd/config.toml
|
omarchy-refresh-config swayosd/config.toml
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config swayosd/style.css
|
omarchy-refresh-config swayosd/style.css
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-swayosd
|
omarchy-restart-swayosd
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config walker/config.toml
|
omarchy-refresh-config walker/config.toml
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-walker
|
omarchy-restart-walker
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config waybar/config.jsonc
|
omarchy-refresh-config waybar/config.jsonc
|
||||||
~/.local/share/omarchy/bin/omarchy-refresh-config waybar/style.css
|
omarchy-refresh-config waybar/style.css
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-waybar
|
omarchy-restart-waybar
|
||||||
|
4
bin/omarchy-reset-sudo
Executable file
4
bin/omarchy-reset-sudo
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo "Resetting sudo lockout for user: $USER"
|
||||||
|
su -c "faillock --reset --user $USER"
|
@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-app hypridle
|
omarchy-restart-app hypridle
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-app hyprsunset
|
omarchy-restart-app hyprsunset
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-app swayosd-server
|
omarchy-restart-app swayosd-server
|
||||||
|
@ -1,4 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
pkill walker
|
pkill walker
|
||||||
setsid uwsm app -- walker --gapplication-service &
|
# FIXME: Reenable the walker service once the memory leak has been fixed
|
||||||
|
# See https://github.com/basecamp/omarchy/issues/698
|
||||||
|
# setsid uwsm app -- walker --gapplication-service &
|
||||||
|
echo # Always end in success so we don't terminate further running
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-app waybar
|
omarchy-restart-app waybar
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-app fcitx5
|
omarchy-restart-app fcitx5
|
||||||
|
89
bin/omarchy-setup-dns
Executable file
89
bin/omarchy-setup-dns
Executable file
@ -0,0 +1,89 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [[ -z $1 ]]; then
|
||||||
|
dns=$(gum choose --height 5 --header "Select DNS provider" Cloudflare DHCP Custom)
|
||||||
|
else
|
||||||
|
dns=$1
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$dns" in
|
||||||
|
Cloudflare)
|
||||||
|
sudo tee /etc/systemd/resolved.conf >/dev/null <<'EOF'
|
||||||
|
[Resolve]
|
||||||
|
DNS=1.1.1.1#cloudflare-dns.com 1.0.0.1#cloudflare-dns.com
|
||||||
|
FallbackDNS=9.9.9.9 149.112.112.112
|
||||||
|
DNSOverTLS=opportunistic
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Ensure network interfaces don't override our DNS settings
|
||||||
|
for file in /etc/systemd/network/*.network; do
|
||||||
|
[[ -f "$file" ]] || continue
|
||||||
|
if ! grep -q "^\[DHCPv4\]" "$file"; then continue; fi
|
||||||
|
|
||||||
|
# Add UseDNS=no to DHCPv4 section if not present
|
||||||
|
if ! sed -n '/^\[DHCPv4\]/,/^\[/p' "$file" | grep -q "^UseDNS="; then
|
||||||
|
sudo sed -i '/^\[DHCPv4\]/a UseDNS=no' "$file"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Add UseDNS=no to IPv6AcceptRA section if present
|
||||||
|
if grep -q "^\[IPv6AcceptRA\]" "$file" && ! sed -n '/^\[IPv6AcceptRA\]/,/^\[/p' "$file" | grep -q "^UseDNS="; then
|
||||||
|
sudo sed -i '/^\[IPv6AcceptRA\]/a UseDNS=no' "$file"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
sudo systemctl restart systemd-networkd systemd-resolved
|
||||||
|
;;
|
||||||
|
|
||||||
|
DHCP)
|
||||||
|
sudo tee /etc/systemd/resolved.conf >/dev/null <<'EOF'
|
||||||
|
[Resolve]
|
||||||
|
DNS=
|
||||||
|
FallbackDNS=
|
||||||
|
DNSOverTLS=no
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Allow network interfaces to use DHCP DNS
|
||||||
|
for file in /etc/systemd/network/*.network; do
|
||||||
|
[[ -f "$file" ]] || continue
|
||||||
|
sudo sed -i '/^UseDNS=no/d' "$file"
|
||||||
|
done
|
||||||
|
|
||||||
|
sudo systemctl restart systemd-networkd systemd-resolved
|
||||||
|
;;
|
||||||
|
|
||||||
|
Custom)
|
||||||
|
echo "Enter your DNS servers (space-separated, e.g. '192.168.1.1 1.1.1.1'):"
|
||||||
|
read -r dns_servers
|
||||||
|
|
||||||
|
if [[ -z "$dns_servers" ]]; then
|
||||||
|
echo "Error: No DNS servers provided."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
sudo tee /etc/systemd/resolved.conf >/dev/null <<EOF
|
||||||
|
[Resolve]
|
||||||
|
DNS=$dns_servers
|
||||||
|
FallbackDNS=9.9.9.9 149.112.112.112
|
||||||
|
EOF
|
||||||
|
|
||||||
|
# Ensure network interfaces don't override our DNS settings
|
||||||
|
for file in /etc/systemd/network/*.network; do
|
||||||
|
[[ -f "$file" ]] || continue
|
||||||
|
if ! grep -q "^\[DHCPv4\]" "$file"; then continue; fi
|
||||||
|
|
||||||
|
# Add UseDNS=no to DHCPv4 section if not present
|
||||||
|
if ! sed -n '/^\[DHCPv4\]/,/^\[/p' "$file" | grep -q "^UseDNS="; then
|
||||||
|
sudo sed -i '/^\[DHCPv4\]/a UseDNS=no' "$file"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Add UseDNS=no to IPv6AcceptRA section if present
|
||||||
|
if grep -q "^\[IPv6AcceptRA\]" "$file" && ! sed -n '/^\[IPv6AcceptRA\]/,/^\[/p' "$file" | grep -q "^UseDNS="; then
|
||||||
|
sudo sed -i '/^\[IPv6AcceptRA\]/a UseDNS=no' "$file"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
sudo systemctl restart systemd-networkd systemd-resolved
|
||||||
|
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
@ -1,43 +1,127 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
set -e
|
||||||
|
|
||||||
if [[ "--remove" == "$1" ]]; then
|
GREEN='\033[0;32m'
|
||||||
echo -e "\e[32mLet's remove your Fido2 device from sudo authentication.\n\e[0m"
|
RED='\033[0;31m'
|
||||||
yay -Rns --noconfirm libfido2 pam-u2f
|
YELLOW='\033[1;33m'
|
||||||
sudo rm -rf /etc/fido2
|
NC='\033[0m' # No Color
|
||||||
sudo sed -i '\|^auth[[:space:]]\+sufficient[[:space:]]\+pam_u2f\.so[[:space:]]\+cue[[:space:]]\+authfile=/etc/fido2/fido2$|d' /etc/pam.d/sudo
|
|
||||||
echo -e "\e[32m\nYou've successfully removed the fido2 device setup.\e[0m"
|
|
||||||
else
|
|
||||||
echo -e "\e[32mLet's setup your Fido2 device for sudo authentication.\n\e[0m"
|
|
||||||
yay -S --noconfirm --needed libfido2 pam-u2f
|
|
||||||
|
|
||||||
tokens=$(fido2-token -L)
|
print_success() {
|
||||||
|
echo -e "${GREEN}$1${NC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
print_error() {
|
||||||
|
echo -e "${RED}$1${NC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
print_info() {
|
||||||
|
echo -e "${YELLOW}$1${NC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
check_fido2_hardware() {
|
||||||
|
tokens=$(fido2-token -L 2>/dev/null)
|
||||||
if [ -z "$tokens" ]; then
|
if [ -z "$tokens" ]; then
|
||||||
echo -e "\e[31m\nNo fido2 device detected. Plug it in, you may have to unlock it as well\e[0m"
|
print_error "\nNo FIDO2 device detected. Please plug it in (you may need to unlock it as well)."
|
||||||
else
|
return 1
|
||||||
# Create the pamu2fcfg file
|
|
||||||
if [ ! -f /etc/fido2/fido2 ]; then
|
|
||||||
sudo mkdir -p /etc/fido2
|
|
||||||
echo -e "\e[32m\nLet's setup your device by confirming on the device now.\e[0m"
|
|
||||||
pamu2fcfg >/tmp/fido2 # This needs to run as the user
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo -e "\e[31m\nSomething went wrong. Maybe try again?\e[0m"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
sudo mv /tmp/fido2 /etc/fido2/fido2
|
|
||||||
fi
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
# Add fido2 auth as an option for sudo
|
setup_pam_config() {
|
||||||
|
# Configure sudo
|
||||||
if ! grep -q pam_u2f.so /etc/pam.d/sudo; then
|
if ! grep -q pam_u2f.so /etc/pam.d/sudo; then
|
||||||
|
print_info "Configuring sudo for FIDO2 authentication..."
|
||||||
sudo sed -i '1i auth sufficient pam_u2f.so cue authfile=/etc/fido2/fido2' /etc/pam.d/sudo
|
sudo sed -i '1i auth sufficient pam_u2f.so cue authfile=/etc/fido2/fido2' /etc/pam.d/sudo
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! sudo echo -e "\e[32m\nPerfect! Now you can use your fido2 device for sudo.\e[0m"; then
|
# Configure polkit
|
||||||
echo -e "\e[31m\nSomething went wrong. Maybe try again?\e[0m"
|
if [ -f /etc/pam.d/polkit-1 ] && ! grep -q 'pam_u2f.so' /etc/pam.d/polkit-1; then
|
||||||
|
print_info "Configuring polkit for FIDO2 authentication..."
|
||||||
|
sudo sed -i '1i auth sufficient pam_u2f.so cue authfile=/etc/fido2/fido2' /etc/pam.d/polkit-1
|
||||||
|
elif [ ! -f /etc/pam.d/polkit-1 ]; then
|
||||||
|
print_info "Creating polkit configuration with FIDO2 authentication..."
|
||||||
|
sudo tee /etc/pam.d/polkit-1 >/dev/null <<'EOF'
|
||||||
|
auth sufficient pam_u2f.so cue authfile=/etc/fido2/fido2
|
||||||
|
auth required pam_unix.so
|
||||||
|
|
||||||
|
account required pam_unix.so
|
||||||
|
password required pam_unix.so
|
||||||
|
session required pam_unix.so
|
||||||
|
EOF
|
||||||
fi
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
remove_pam_config() {
|
||||||
|
# Remove from sudo
|
||||||
|
if grep -q pam_u2f.so /etc/pam.d/sudo; then
|
||||||
|
print_info "Removing FIDO2 authentication from sudo..."
|
||||||
|
sudo sed -i '/pam_u2f\.so/d' /etc/pam.d/sudo
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove from polkit
|
||||||
|
if [ -f /etc/pam.d/polkit-1 ] && grep -Fq 'pam_u2f.so' /etc/pam.d/polkit-1; then
|
||||||
|
print_info "Removing FIDO2 authentication from polkit..."
|
||||||
|
sudo sed -i '/pam_u2f\.so/d' /etc/pam.d/polkit-1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ "--remove" == "$1" ]]; then
|
||||||
|
print_success "Removing FIDO2 device from authentication.\n"
|
||||||
|
|
||||||
|
# Remove PAM configuration
|
||||||
|
remove_pam_config
|
||||||
|
|
||||||
|
# Remove FIDO2 configuration
|
||||||
|
if [ -d /etc/fido2 ]; then
|
||||||
|
print_info "Removing FIDO2 configuration..."
|
||||||
|
sudo rm -rf /etc/fido2
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Uninstall packages
|
||||||
|
print_info "Removing FIDO2 packages..."
|
||||||
|
sudo pacman -Rns --noconfirm libfido2 pam-u2f
|
||||||
|
|
||||||
|
print_success "FIDO2 authentication has been completely removed."
|
||||||
|
else
|
||||||
|
print_success "Setting up FIDO2 device for authentication.\n"
|
||||||
|
|
||||||
|
# Install required packages
|
||||||
|
print_info "Installing required packages..."
|
||||||
|
sudo pacman -S --noconfirm --needed libfido2 pam-u2f
|
||||||
|
|
||||||
|
if ! check_fido2_hardware; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create the pamu2fcfg file
|
||||||
|
if [ ! -f /etc/fido2/fido2 ]; then
|
||||||
|
sudo mkdir -p /etc/fido2
|
||||||
|
print_success "\nLet's setup your device by confirming on the device now."
|
||||||
|
print_info "Touch your FIDO2 key when it lights up...\n"
|
||||||
|
|
||||||
|
if pamu2fcfg >/tmp/fido2; then
|
||||||
|
sudo mv /tmp/fido2 /etc/fido2/fido2
|
||||||
|
print_success "FIDO2 device registered successfully!"
|
||||||
|
else
|
||||||
|
print_error "\nFIDO2 registration failed. Please try again."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
print_info "FIDO2 device already registered."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Configure PAM
|
||||||
|
setup_pam_config
|
||||||
|
|
||||||
|
# Test with sudo
|
||||||
|
print_info "\nTesting FIDO2 authentication with sudo..."
|
||||||
|
print_info "Touch your FIDO2 key when prompted.\n"
|
||||||
|
|
||||||
|
if sudo echo "FIDO2 authentication test successful"; then
|
||||||
|
print_success "\nPerfect! FIDO2 authentication is now configured."
|
||||||
|
print_info "You can use your FIDO2 key for sudo and polkit authentication."
|
||||||
|
else
|
||||||
|
print_error "\nVerification failed. You may want to check your configuration."
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
||||||
|
@ -1,49 +1,112 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
set -e
|
||||||
|
|
||||||
if [[ "--remove" == "$1" ]]; then
|
GREEN='\033[0;32m'
|
||||||
echo -e "\e[32mLet's remove your fingerprint scanner from authentication.\n\e[0m"
|
RED='\033[0;31m'
|
||||||
yay -Rns --noconfirm fprintd
|
YELLOW='\033[1;33m'
|
||||||
sudo rm -rf /etc/pam.d/polkit-1
|
NC='\033[0m' # No Color
|
||||||
sudo sed -i '/pam_fprintd\.so/d' /etc/pam.d/sudo
|
|
||||||
echo -e "\e[32mYou've successfully removed the fingerprint setup.\e[0m"
|
|
||||||
else
|
|
||||||
echo -e "\e[32mLet's setup your fingerprint scanner for authentication.\n\e[0m"
|
|
||||||
yay -S --noconfirm --needed fprintd usbutils
|
|
||||||
|
|
||||||
if ! lsusb | grep -Eiq 'fingerprint|synaptics|goodix'; then
|
print_success() {
|
||||||
echo -e "\e[31m\nNo fingerprint sensor detected.\e[0m"
|
echo -e "${GREEN}$1${NC}"
|
||||||
else
|
}
|
||||||
# Add fingerprint authentication as an option for sudo
|
|
||||||
|
print_error() {
|
||||||
|
echo -e "${RED}$1${NC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
print_info() {
|
||||||
|
echo -e "${YELLOW}$1${NC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
check_fingerprint_hardware() {
|
||||||
|
if ! lsusb | grep -Eiq 'fingerprint|synaptics|goodix|elan|validity'; then
|
||||||
|
print_error "\nNo fingerprint sensor detected."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
setup_pam_config() {
|
||||||
|
# Configure sudo
|
||||||
if ! grep -q pam_fprintd.so /etc/pam.d/sudo; then
|
if ! grep -q pam_fprintd.so /etc/pam.d/sudo; then
|
||||||
|
print_info "Configuring sudo for fingerprint authentication..."
|
||||||
sudo sed -i '1i auth sufficient pam_fprintd.so' /etc/pam.d/sudo
|
sudo sed -i '1i auth sufficient pam_fprintd.so' /etc/pam.d/sudo
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Add fingerprint authentication as an option for hyprpolkitagent
|
# Configure polkit
|
||||||
if [ ! -f /etc/pam.d/polkit-1 ] || ! grep -q pam_fprintd.so /etc/pam.d/polkit-1; then
|
if [ -f /etc/pam.d/polkit-1 ] && ! grep -q 'pam_fprintd.so' /etc/pam.d/polkit-1; then
|
||||||
|
print_info "Configuring polkit for fingerprint authentication..."
|
||||||
|
sudo sed -i '1i auth sufficient pam_fprintd.so' /etc/pam.d/polkit-1
|
||||||
|
elif [ ! -f /etc/pam.d/polkit-1 ]; then
|
||||||
|
print_info "Creating polkit configuration with fingerprint authentication..."
|
||||||
sudo tee /etc/pam.d/polkit-1 >/dev/null <<'EOF'
|
sudo tee /etc/pam.d/polkit-1 >/dev/null <<'EOF'
|
||||||
|
auth sufficient pam_fprintd.so
|
||||||
auth required pam_unix.so
|
auth required pam_unix.so
|
||||||
auth optional pam_fprintd.so
|
|
||||||
|
|
||||||
account required pam_unix.so
|
account required pam_unix.so
|
||||||
password required pam_unix.so
|
password required pam_unix.so
|
||||||
session required pam_unix.so
|
session required pam_unix.so
|
||||||
EOF
|
EOF
|
||||||
fi
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# Enroll the first finger
|
remove_pam_config() {
|
||||||
echo -e "\e[32m\nLet's setup your right index finger as the first fingerprint.\nKeep moving the finger around on sensor until the process completes.\n\e[0m"
|
# Remove from sudo
|
||||||
sudo fprintd-enroll $USER
|
if grep -q pam_fprintd.so /etc/pam.d/sudo; then
|
||||||
|
print_info "Removing fingerprint authentication from sudo..."
|
||||||
echo -e "\e[32m\nNow let's verify that it's working correctly.\e[0m\n"
|
sudo sed -i '/pam_fprintd\.so/d' /etc/pam.d/sudo
|
||||||
|
|
||||||
if fprintd-verify; then
|
|
||||||
echo -e "\e[32m\nPerfect! Now you can use your fingerprint on the lock screen (Super + Escape).\e[0m"
|
|
||||||
else
|
|
||||||
echo -e "\e[31m\nSomething went wrong. Maybe try again?\e[0m"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Remove from polkit
|
||||||
|
if [ -f /etc/pam.d/polkit-1 ] && grep -Fq 'pam_fprintd.so' /etc/pam.d/polkit-1; then
|
||||||
|
print_info "Removing fingerprint authentication from polkit..."
|
||||||
|
sudo sed -i '/pam_fprintd\.so/d' /etc/pam.d/polkit-1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ "--remove" == "$1" ]]; then
|
||||||
|
print_success "Removing fingerprint scanner from authentication.\n"
|
||||||
|
|
||||||
|
# Remove PAM configuration
|
||||||
|
remove_pam_config
|
||||||
|
|
||||||
|
# Uninstall packages
|
||||||
|
print_info "Removing fingerprint packages..."
|
||||||
|
sudo pacman -Rns --noconfirm fprintd
|
||||||
|
|
||||||
|
print_success "Fingerprint authentication has been completely removed."
|
||||||
|
else
|
||||||
|
print_success "Setting up fingerprint scanner for authentication.\n"
|
||||||
|
|
||||||
|
# Install required packages
|
||||||
|
print_info "Installing required packages..."
|
||||||
|
sudo pacman -S --noconfirm --needed fprintd usbutils
|
||||||
|
|
||||||
|
if ! check_fingerprint_hardware; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Configure PAM
|
||||||
|
setup_pam_config
|
||||||
|
|
||||||
|
# Enroll first fingerprint
|
||||||
|
print_success "\nLet's setup your right index finger as the first fingerprint."
|
||||||
|
print_info "Keep moving the finger around on sensor until the process completes.\n"
|
||||||
|
|
||||||
|
if sudo fprintd-enroll "$USER"; then
|
||||||
|
print_success "\nFingerprint enrolled successfully!"
|
||||||
|
|
||||||
|
# Verify
|
||||||
|
print_info "\nNow let's verify that it's working correctly.\n"
|
||||||
|
if fprintd-verify; then
|
||||||
|
print_success "\nPerfect! Fingerprint authentication is now configured."
|
||||||
|
print_info "You can use your fingerprint for sudo, polkit, and lock screen (Super + Escape)."
|
||||||
|
else
|
||||||
|
print_error "\nVerification failed. You may want to try enrolling again."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
print_error "\nEnrollment failed. Please try again."
|
||||||
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
echo
|
echo
|
||||||
gum spin --spinner "globe" --title "Done!" -- sleep 2
|
gum spin --spinner "globe" --title "Done! Press any key to close..." -- bash -c 'read -n 1 -s'
|
||||||
clear
|
|
||||||
|
26
bin/omarchy-snapshot
Executable file
26
bin/omarchy-snapshot
Executable file
@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
COMMAND="$1"
|
||||||
|
OMARCHY_PATH=${OMARCHY_PATH:-$HOME/.local/share/omarchy}
|
||||||
|
|
||||||
|
if [[ -z $COMMAND ]]; then
|
||||||
|
echo "Usage: omarchy-snapshot <create|restore>" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! command -v snapper &>/dev/null; then
|
||||||
|
exit 127 # omarchy-update can use this to just ignore if snapper is not available
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$COMMAND" in
|
||||||
|
create)
|
||||||
|
DESC="$(omarchy-version)"
|
||||||
|
|
||||||
|
for config in root home; do
|
||||||
|
sudo snapper -c "$config" create -c number -d "$DESC"
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
restore)
|
||||||
|
sudo limine-snapper-restore
|
||||||
|
;;
|
||||||
|
esac
|
22
bin/omarchy-state
Executable file
22
bin/omarchy-state
Executable file
@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
STATE_DIR="$HOME/.local/state/omarchy"
|
||||||
|
mkdir -p "$STATE_DIR"
|
||||||
|
|
||||||
|
COMMAND="$1"
|
||||||
|
STATE_NAME="$2"
|
||||||
|
|
||||||
|
if [[ -z "$COMMAND" ]]; then
|
||||||
|
echo "Usage: omarchy-state <set|clear> <state-name-or-pattern>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$STATE_NAME" ]]; then
|
||||||
|
echo "Usage: omarchy-state $COMMAND <state-name>"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$COMMAND" in
|
||||||
|
set) touch "$STATE_DIR/$STATE_NAME" ;;
|
||||||
|
clear) find "$STATE_DIR" -maxdepth 1 -type f -name "$STATE_NAME" -delete ;;
|
||||||
|
esac
|
3
bin/omarchy-theme-current
Executable file
3
bin/omarchy-theme-current
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
basename "$(realpath "$HOME/.config/omarchy/current/theme")" | sed -E 's/(^|-)([a-z])/\1\u\2/g; s/-/ /g'
|
@ -4,7 +4,6 @@
|
|||||||
# Usage: omarchy-theme-install <git-repo-url>
|
# Usage: omarchy-theme-install <git-repo-url>
|
||||||
|
|
||||||
if [ -z "$1" ]; then
|
if [ -z "$1" ]; then
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
|
||||||
echo -e "\e[32mSee https://manuals.omamix.org/2/the-omarchy-manual/90/extra-themes\n\e[0m"
|
echo -e "\e[32mSee https://manuals.omamix.org/2/the-omarchy-manual/90/extra-themes\n\e[0m"
|
||||||
REPO_URL=$(gum input --placeholder="Git repo URL for theme" --header="")
|
REPO_URL=$(gum input --placeholder="Git repo URL for theme" --header="")
|
||||||
else
|
else
|
||||||
@ -31,4 +30,4 @@ if ! git clone "$REPO_URL" "$THEME_PATH"; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Apply the new theme with omarchy-theme-set
|
# Apply the new theme with omarchy-theme-set
|
||||||
~/.local/share/omarchy/bin/omarchy-theme-set $THEME_NAME
|
omarchy-theme-set $THEME_NAME
|
||||||
|
@ -1,21 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
THEMES_DIR="$HOME/.config/omarchy/themes/"
|
find ~/.config/omarchy/themes/ -mindepth 1 -maxdepth 1 \( -type d -o -type l \) | sort | while read -r path; do
|
||||||
CURRENT_THEME_DIR="$HOME/.config/omarchy/current/theme"
|
echo "$(basename "$path" | sed -E 's/(^|-)([a-z])/\1\u\2/g; s/-/ /g')"
|
||||||
CURRENT_THEME_NAME=$(basename "$(realpath "$CURRENT_THEME_DIR")")
|
done
|
||||||
|
|
||||||
# Build themes list with pretty display names
|
|
||||||
mapfile -t themes < <(
|
|
||||||
find "$THEMES_DIR" -mindepth 1 -maxdepth 1 \( -type d -o -type l \) | sort | while read -r path; do
|
|
||||||
filename=$(basename "$path")
|
|
||||||
display_name=$(echo "$filename" | sed -E 's/(^|-)([a-z])/\1\u\2/g; s/-/ /g')
|
|
||||||
|
|
||||||
if [[ "$filename" == "$CURRENT_THEME_NAME" ]]; then
|
|
||||||
echo "<i>$display_name</i>"
|
|
||||||
else
|
|
||||||
echo "$display_name"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
)
|
|
||||||
|
|
||||||
printf '%s\n' "${themes[@]}"
|
|
||||||
|
@ -30,5 +30,5 @@ NEXT_INDEX=$(((INDEX + 1) % TOTAL))
|
|||||||
NEW_THEME=${THEMES[$NEXT_INDEX]}
|
NEW_THEME=${THEMES[$NEXT_INDEX]}
|
||||||
NEW_THEME_NAME=$(basename "$NEW_THEME")
|
NEW_THEME_NAME=$(basename "$NEW_THEME")
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-theme-set $NEW_THEME_NAME
|
omarchy-theme-set $NEW_THEME_NAME
|
||||||
notify-send "Theme changed to $NEW_THEME_NAME" -t 2000
|
notify-send "Theme changed to $NEW_THEME_NAME" -t 2000
|
||||||
|
@ -4,11 +4,10 @@
|
|||||||
# Usage: omarchy-theme-remove <theme-name>
|
# Usage: omarchy-theme-remove <theme-name>
|
||||||
|
|
||||||
if [ -z "$1" ]; then
|
if [ -z "$1" ]; then
|
||||||
extra_themes=$(find ~/.config/omarchy/themes -mindepth 1 -maxdepth 1 -type d ! -xtype l -printf '%f\n')
|
mapfile -t extra_themes < <(find ~/.config/omarchy/themes -mindepth 1 -maxdepth 1 -type d ! -xtype l -printf '%f\n')
|
||||||
|
|
||||||
if [[ -n "$extra_themes" ]]; then
|
if [[ ${#extra_themes[@]} -gt 0 ]]; then
|
||||||
# THEME_NAME=$(gum choose --header="Remove extra theme" "$extra_themes")
|
THEME_NAME=$(gum choose --header="Remove extra theme" "${extra_themes[@]}")
|
||||||
THEME_NAME=$(echo -e "$extra_themes" | gum choose --header="Remove extra theme")
|
|
||||||
else
|
else
|
||||||
echo "No extra themes installed."
|
echo "No extra themes installed."
|
||||||
exit 1
|
exit 1
|
||||||
@ -34,7 +33,7 @@ fi
|
|||||||
|
|
||||||
# Move to the next theme if the current theme is the one being removed
|
# Move to the next theme if the current theme is the one being removed
|
||||||
if [ "$(readlink -f "$CURRENT_DIR/theme")" = "$(readlink -f "$THEME_PATH")" ]; then
|
if [ "$(readlink -f "$CURRENT_DIR/theme")" = "$(readlink -f "$THEME_PATH")" ]; then
|
||||||
~/.local/share/omarchy/bin/omarchy-theme-next
|
omarchy-theme-next
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Now remove the theme directory for THEME_NAME
|
# Now remove the theme directory for THEME_NAME
|
||||||
|
@ -39,16 +39,31 @@ else
|
|||||||
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
gsettings set org.gnome.desktop.interface icon-theme "Yaru-blue"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Change Chromium colors
|
||||||
|
if command -v chromium &>/dev/null; then
|
||||||
|
if [[ -f ~/.config/omarchy/current/theme/light.mode ]]; then
|
||||||
|
chromium --no-startup-window --set-color-scheme="light"
|
||||||
|
else
|
||||||
|
chromium --no-startup-window --set-color-scheme="dark"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -f ~/.config/omarchy/current/theme/chromium.theme ]]; then
|
||||||
|
chromium --no-startup-window --set-theme-color="$(<~/.config/omarchy/current/theme/chromium.theme)"
|
||||||
|
else
|
||||||
|
# Use a default, neutral grey if theme doesn't have a color
|
||||||
|
chromium --no-startup-window --set-theme-color="28,32,39"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Trigger alacritty config reload
|
# Trigger alacritty config reload
|
||||||
touch "$HOME/.config/alacritty/alacritty.toml"
|
touch "$HOME/.config/alacritty/alacritty.toml"
|
||||||
|
|
||||||
# Restart components to apply new theme
|
# Restart components to apply new theme
|
||||||
pkill -SIGUSR2 btop
|
pkill -SIGUSR2 btop
|
||||||
~/.local/share/omarchy/bin/omarchy-restart-waybar
|
omarchy-restart-waybar
|
||||||
pkill swayosd-server
|
omarchy-restart-swayosd
|
||||||
setsid uwsm app -- swayosd-server &>/dev/null &
|
|
||||||
makoctl reload
|
makoctl reload
|
||||||
hyprctl reload
|
hyprctl reload
|
||||||
|
|
||||||
# Set new background
|
# Set new background
|
||||||
~/.local/share/omarchy/bin/omarchy-theme-bg-next
|
omarchy-theme-bg-next
|
||||||
|
@ -1,9 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
|
||||||
|
|
||||||
for dir in ~/.config/omarchy/themes/*/; do
|
for dir in ~/.config/omarchy/themes/*/; do
|
||||||
[ -d "$dir" ] && [ ! -L "${dir%/}" ] && echo "Updating: $(basename "$dir")" && git -C "$dir" pull
|
[ -d "$dir" ] && [ ! -L "${dir%/}" ] && echo "Updating: $(basename "$dir")" && git -C "$dir" pull
|
||||||
done
|
done
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
||||||
|
12
bin/omarchy-toggle-screensaver
Executable file
12
bin/omarchy-toggle-screensaver
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
STATE_FILE=~/.local/state/omarchy/toggles/screensaver-off
|
||||||
|
|
||||||
|
if [[ -f $STATE_FILE ]]; then
|
||||||
|
rm -f $STATE_FILE
|
||||||
|
notify-send " Screensaver enabled"
|
||||||
|
else
|
||||||
|
mkdir -p "$(dirname $STATE_FILE)"
|
||||||
|
touch $STATE_FILE
|
||||||
|
notify-send " Screensaver disabled"
|
||||||
|
fi
|
7
bin/omarchy-toggle-waybar
Executable file
7
bin/omarchy-toggle-waybar
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if pgrep -x waybar >/dev/null; then
|
||||||
|
pkill -x waybar
|
||||||
|
else
|
||||||
|
uwsm app -- waybar >/dev/null 2>&1 &
|
||||||
|
fi
|
54
bin/omarchy-tui-install
Executable file
54
bin/omarchy-tui-install
Executable file
@ -0,0 +1,54 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ "$#" -ne 4 ]; then
|
||||||
|
echo -e "\e[32mLet's create a TUI shortcut you can start with the app launcher.\n\e[0m"
|
||||||
|
APP_NAME=$(gum input --prompt "Name> " --placeholder "My TUI")
|
||||||
|
APP_EXEC=$(gum input --prompt "Launch Command> " --placeholder "lazydocker or bash -c 'dust; read -n 1 -s'")
|
||||||
|
WINDOW_STYLE=$(gum choose --header "Window style" float tile)
|
||||||
|
ICON_URL=$(gum input --prompt "Icon URL> " --placeholder "See https://dashboardicons.com (must use PNG!)")
|
||||||
|
else
|
||||||
|
APP_NAME="$1"
|
||||||
|
APP_EXEC="$2"
|
||||||
|
WINDOW_STYLE="$3"
|
||||||
|
ICON_URL="$4"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$APP_NAME" || -z "$APP_EXEC" || -z "$ICON_URL" ]]; then
|
||||||
|
echo "You must set app name, app command, and icon URL!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
|
DESKTOP_FILE="$HOME/.local/share/applications/$APP_NAME.desktop"
|
||||||
|
ICON_PATH="$ICON_DIR/$APP_NAME.png"
|
||||||
|
|
||||||
|
mkdir -p "$ICON_DIR"
|
||||||
|
|
||||||
|
if ! curl -sL -o "$ICON_PATH" "$ICON_URL"; then
|
||||||
|
echo "Error: Failed to download icon."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $WINDOW_STYLE == "float" ]]; then
|
||||||
|
APP_CLASS="TUI.float"
|
||||||
|
else
|
||||||
|
APP_CLASS="TUI.tile"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat >"$DESKTOP_FILE" <<EOF
|
||||||
|
[Desktop Entry]
|
||||||
|
Version=1.0
|
||||||
|
Name=$APP_NAME
|
||||||
|
Comment=$APP_NAME
|
||||||
|
Exec=alacritty --class $APP_CLASS -e $APP_EXEC
|
||||||
|
Terminal=false
|
||||||
|
Type=Application
|
||||||
|
Icon=$ICON_PATH
|
||||||
|
StartupNotify=true
|
||||||
|
EOF
|
||||||
|
|
||||||
|
chmod +x "$DESKTOP_FILE"
|
||||||
|
|
||||||
|
if [ "$#" -ne 4 ]; then
|
||||||
|
echo -e "You can now find $APP_NAME using the app launcher (SUPER + SPACE)\n"
|
||||||
|
fi
|
36
bin/omarchy-tui-remove
Executable file
36
bin/omarchy-tui-remove
Executable file
@ -0,0 +1,36 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
|
DESKTOP_DIR="$HOME/.local/share/applications/"
|
||||||
|
|
||||||
|
if [ "$#" -ne 1 ]; then
|
||||||
|
# Find all web apps
|
||||||
|
while IFS= read -r -d '' file; do
|
||||||
|
if grep -q '^Exec=.*alacritty.*-e' "$file"; then
|
||||||
|
TUIS+=("$(basename "${file%.desktop}")")
|
||||||
|
fi
|
||||||
|
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
||||||
|
|
||||||
|
if ((${#TUIS[@]})); then
|
||||||
|
IFS=$'\n' SORTED_TUIS=($(sort <<<"${TUIS[*]}"))
|
||||||
|
unset IFS
|
||||||
|
APP_NAME=$(gum choose --header "Select TUI to remove..." "${SORTED_TUIS[@]}")
|
||||||
|
else
|
||||||
|
echo "No TUIs to remove."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
APP_NAME="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -z "$APP_NAME" ]]; then
|
||||||
|
echo "You must provide TUI name."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm "$DESKTOP_DIR/$APP_NAME.desktop"
|
||||||
|
rm "$ICON_DIR/$APP_NAME.png"
|
||||||
|
|
||||||
|
if [ "$#" -ne 1 ]; then
|
||||||
|
echo -e "Removed $APP_NAME\n"
|
||||||
|
fi
|
@ -1,27 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Exit immediately if a command exits with a non-zero status
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
# Show logo
|
omarchy-snapshot create || [ $? -eq 127 ]
|
||||||
clear
|
omarchy-update-git
|
||||||
cat <~/.local/share/omarchy/logo.txt
|
omarchy-migrate
|
||||||
|
omarchy-update-system-pkgs
|
||||||
# Get the latest while trying to preserve any modifications
|
omarchy-update-restart
|
||||||
omarchy_path=~/.local/share/omarchy
|
omarchy-restart-waybar # removes update-available icon
|
||||||
git -C $omarchy_path pull --autostash
|
|
||||||
git -C $omarchy_path diff --check || git -C $omarchy_path reset --merge
|
|
||||||
|
|
||||||
# Run migrations
|
|
||||||
~/.local/share/omarchy/bin/omarchy-migrate
|
|
||||||
|
|
||||||
# Update system packages
|
|
||||||
echo -e "\e[32m\nUpdate system packages\e[0m"
|
|
||||||
yay -Syu --noconfirm
|
|
||||||
|
|
||||||
# Offer to reboot if the kernel has been changed
|
|
||||||
if [ "$(uname -r | sed 's/-arch/\.arch/')" != "$(pacman -Q linux | awk '{print $2}')" ]; then
|
|
||||||
gum confirm "Linux kernel has been updated. Reboot?" && sudo reboot now
|
|
||||||
fi
|
|
||||||
|
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
||||||
|
@ -1,15 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
omarchy_path="$HOME/.local/share/omarchy"
|
|
||||||
|
|
||||||
# Ensure remote is reachable
|
# Ensure remote is reachable
|
||||||
if ! git -C "$omarchy_path" ls-remote &>/dev/null; then
|
if ! git -C "$OMARCHY_PATH" ls-remote &>/dev/null; then
|
||||||
echo "Error: Unable to reach remote repository."
|
echo "Error: Unable to reach remote repository."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
latest_tag=$(git -C "$omarchy_path" ls-remote --tags origin | grep -v "{}" | awk '{print $2}' | sed 's#refs/tags/##' | sort -V | tail -n 1)
|
latest_tag=$(git -C "$OMARCHY_PATH" ls-remote --tags origin | grep -v "{}" | awk '{print $2}' | sed 's#refs/tags/##' | sort -V | tail -n 1)
|
||||||
current_tag=$(git -C "$omarchy_path" describe --tags $(git -C "$omarchy_path" rev-list --tags --max-count=1))
|
current_tag=$(git -C "$OMARCHY_PATH" describe --tags $(git -C "$OMARCHY_PATH" rev-list --tags --max-count=1))
|
||||||
|
|
||||||
if [[ "$current_tag" != "$latest_tag" ]]; then
|
if [[ "$current_tag" != "$latest_tag" ]]; then
|
||||||
echo "Omarchy update available ($latest_tag)"
|
echo "Omarchy update available ($latest_tag)"
|
||||||
|
5
bin/omarchy-update-git
Executable file
5
bin/omarchy-update-git
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo -e "\e[32mUpdate Omarchy\e[0m"
|
||||||
|
git -C $OMARCHY_PATH pull --autostash
|
||||||
|
git -C $OMARCHY_PATH diff --check || git -C $OMARCHY_PATH reset --merge
|
21
bin/omarchy-update-restart
Executable file
21
bin/omarchy-update-restart
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ "$(uname -r | sed 's/-arch/\.arch/')" != "$(pacman -Q linux | awk '{print $2}')" ]; then
|
||||||
|
gum confirm "Linux kernel has been updated. Reboot?" && omarchy-state clear re*-required && sudo reboot now
|
||||||
|
|
||||||
|
elif [ -f "$HOME/.local/state/omarchy/reboot-required" ]; then
|
||||||
|
gum confirm "Updates require reboot. Ready?" && omarchy-state clear re*-required && sudo reboot now
|
||||||
|
|
||||||
|
elif [ -f "$HOME/.local/state/omarchy/relaunch-required" ]; then
|
||||||
|
gum confirm "Updates require Hyprland relaunch. Ready?" && omarchy-state clear re*-required && uwsm stop
|
||||||
|
fi
|
||||||
|
|
||||||
|
for file in "$HOME"/.local/state/omarchy/restart-*-required; do
|
||||||
|
if [ -f "$file" ]; then
|
||||||
|
filename=$(basename "$file")
|
||||||
|
service=$(echo "$filename" | sed 's/restart-\(.*\)-required/\1/')
|
||||||
|
echo "Restarting $service"
|
||||||
|
omarchy-state clear "$filename"
|
||||||
|
omarchy-restart-"$service"
|
||||||
|
fi
|
||||||
|
done
|
23
bin/omarchy-update-system-pkgs
Executable file
23
bin/omarchy-update-system-pkgs
Executable file
@ -0,0 +1,23 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo -e "\e[32m\nUpdate system packages\e[0m"
|
||||||
|
sudo pacman -Syu --noconfirm
|
||||||
|
echo
|
||||||
|
|
||||||
|
if omarchy-pkg-aur-accessible; then
|
||||||
|
echo -e "\e[32m\nUpdate AUR packages\e[0m"
|
||||||
|
yay -Syu --noconfirm
|
||||||
|
echo
|
||||||
|
else
|
||||||
|
echo -e "\e[31m\nAUR is unavailable (so skipping updates)\e[0m"
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
orphans=$(pacman -Qtdq)
|
||||||
|
if [[ -n $orphans ]]; then
|
||||||
|
echo -e "\e[32m\nRemove orphan system packages\e[0m"
|
||||||
|
for pkg in $orphans; do
|
||||||
|
sudo pacman -Rs --noconfirm "$pkg" || true
|
||||||
|
done
|
||||||
|
echo
|
||||||
|
fi
|
3
bin/omarchy-version
Executable file
3
bin/omarchy-version
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
git -C "$OMARCHY_PATH" describe --tags $(git -C "$OMARCHY_PATH" rev-list --tags --max-count=1)
|
@ -1,7 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [ "$#" -ne 3 ]; then
|
if [ "$#" -ne 3 ]; then
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
|
||||||
echo -e "\e[32mLet's create a new web app you can start with the app launcher.\n\e[0m"
|
echo -e "\e[32mLet's create a new web app you can start with the app launcher.\n\e[0m"
|
||||||
APP_NAME=$(gum input --prompt "Name> " --placeholder "My favorite web app")
|
APP_NAME=$(gum input --prompt "Name> " --placeholder "My favorite web app")
|
||||||
APP_URL=$(gum input --prompt "URL> " --placeholder "https://example.com")
|
APP_URL=$(gum input --prompt "URL> " --placeholder "https://example.com")
|
||||||
@ -33,7 +32,7 @@ cat >"$DESKTOP_FILE" <<EOF
|
|||||||
Version=1.0
|
Version=1.0
|
||||||
Name=$APP_NAME
|
Name=$APP_NAME
|
||||||
Comment=$APP_NAME
|
Comment=$APP_NAME
|
||||||
Exec=chromium --new-window --ozone-platform=wayland --app="$APP_URL" --name="$APP_NAME" --class="$APP_NAME"
|
Exec=omarchy-launch-webapp $APP_URL
|
||||||
Terminal=false
|
Terminal=false
|
||||||
Type=Application
|
Type=Application
|
||||||
Icon=$ICON_PATH
|
Icon=$ICON_PATH
|
||||||
@ -44,5 +43,4 @@ chmod +x "$DESKTOP_FILE"
|
|||||||
|
|
||||||
if [ "$#" -ne 3 ]; then
|
if [ "$#" -ne 3 ]; then
|
||||||
echo -e "You can now find $APP_NAME using the app launcher (SUPER + SPACE)\n"
|
echo -e "You can now find $APP_NAME using the app launcher (SUPER + SPACE)\n"
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
||||||
fi
|
fi
|
||||||
|
@ -3,12 +3,10 @@
|
|||||||
ICON_DIR="$HOME/.local/share/applications/icons"
|
ICON_DIR="$HOME/.local/share/applications/icons"
|
||||||
DESKTOP_DIR="$HOME/.local/share/applications/"
|
DESKTOP_DIR="$HOME/.local/share/applications/"
|
||||||
|
|
||||||
if [ "$#" -ne 1 ]; then
|
if [ "$#" -eq 0 ]; then
|
||||||
~/.local/share/omarchy/bin/omarchy-show-logo
|
|
||||||
|
|
||||||
# Find all web apps
|
# Find all web apps
|
||||||
while IFS= read -r -d '' file; do
|
while IFS= read -r -d '' file; do
|
||||||
if grep -q '^Exec=.*chromium.*--app' "$file"; then
|
if grep -q '^Exec=.*omarchy-launch-webapp.*' "$file"; then
|
||||||
WEB_APPS+=("$(basename "${file%.desktop}")")
|
WEB_APPS+=("$(basename "${file%.desktop}")")
|
||||||
fi
|
fi
|
||||||
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
done < <(find "$DESKTOP_DIR" -name '*.desktop' -print0)
|
||||||
@ -16,24 +14,22 @@ if [ "$#" -ne 1 ]; then
|
|||||||
if ((${#WEB_APPS[@]})); then
|
if ((${#WEB_APPS[@]})); then
|
||||||
IFS=$'\n' SORTED_WEB_APPS=($(sort <<<"${WEB_APPS[*]}"))
|
IFS=$'\n' SORTED_WEB_APPS=($(sort <<<"${WEB_APPS[*]}"))
|
||||||
unset IFS
|
unset IFS
|
||||||
APP_NAME=$(gum choose --header "Select web app to remove..." "${SORTED_WEB_APPS[@]}")
|
APP_NAMES=$(gum choose --no-limit --header "Select web app to remove..." "${SORTED_WEB_APPS[@]}")
|
||||||
else
|
else
|
||||||
echo "No web apps to remove."
|
echo "No web apps to remove."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
APP_NAME="$1"
|
APP_NAMES="$*"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -z "$APP_NAME" ]]; then
|
if [[ -z "$APP_NAMES" ]]; then
|
||||||
echo "You must provide web app name."
|
echo "You must provide web app names."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rm "$DESKTOP_DIR/$APP_NAME.desktop"
|
for APP_NAME in $APP_NAMES; do
|
||||||
rm "$ICON_DIR/$APP_NAME.png"
|
rm -f "$DESKTOP_DIR/$APP_NAME.desktop"
|
||||||
|
rm -f "$ICON_DIR/$APP_NAME.png"
|
||||||
if [ "$#" -ne 1 ]; then
|
echo "Removed $APP_NAME"
|
||||||
echo -e "Removed $APP_NAME\n"
|
done
|
||||||
~/.local/share/omarchy/bin/omarchy-show-done
|
|
||||||
fi
|
|
||||||
|
10
boot.sh
10
boot.sh
@ -19,12 +19,14 @@ sudo pacman -Sy --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}"
|
||||||
|
|
||||||
echo -e "\nCloning Omarchy from: https://github.com/${OMARCHY_REPO}.git"
|
echo -e "\nCloning Omarchy from: https://git.itsscb.de/itsscb/omarchy.git"
|
||||||
rm -rf ~/.local/share/omarchy/
|
rm -rf ~/.local/share/omarchy/
|
||||||
git clone "https://github.com/${OMARCHY_REPO}.git" ~/.local/share/omarchy >/dev/null
|
# git clone "https://github.com/${OMARCHY_REPO}.git" ~/.local/share/omarchy >/dev/null
|
||||||
|
git clone "https://git.itsscb.de/itsscb/omarchy.git" ~/.local/share/omarchy >/dev/null
|
||||||
|
|
||||||
# Use custom branch if instructed
|
# Use custom branch if instructed, otherwise default to master
|
||||||
if [[ -n "$OMARCHY_REF" ]]; then
|
OMARCHY_REF="${OMARCHY_REF:-master}"
|
||||||
|
if [[ $OMARCHY_REF != "master" ]]; then
|
||||||
echo -e "\eUsing branch: $OMARCHY_REF"
|
echo -e "\eUsing branch: $OMARCHY_REF"
|
||||||
cd ~/.local/share/omarchy
|
cd ~/.local/share/omarchy
|
||||||
git fetch origin "${OMARCHY_REF}" && git checkout "${OMARCHY_REF}"
|
git fetch origin "${OMARCHY_REF}" && git checkout "${OMARCHY_REF}"
|
||||||
|
3
config/brave-flags.conf
Normal file
3
config/brave-flags.conf
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
--ozone-platform=wayland
|
||||||
|
--ozone-platform-hint=wayland
|
||||||
|
--enable-features=TouchpadOverscrollHistoryNavigation
|
15
config/chromium/Default/Preferences
Normal file
15
config/chromium/Default/Preferences
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"extensions": {
|
||||||
|
"theme": {
|
||||||
|
"id": "",
|
||||||
|
"use_system": false,
|
||||||
|
"use_custom": false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"browser": {
|
||||||
|
"theme": {
|
||||||
|
"color_scheme": 2,
|
||||||
|
"user_color": 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,9 +1,13 @@
|
|||||||
{
|
{
|
||||||
"$schema": "https://github.com/fastfetch-cli/fastfetch/raw/dev/doc/json_schema.json",
|
"$schema": "https://github.com/fastfetch-cli/fastfetch/raw/dev/doc/json_schema.json",
|
||||||
"logo": {
|
"logo": {
|
||||||
|
"type": "file",
|
||||||
|
"source": "~/.config/omarchy/branding/about.txt",
|
||||||
|
"color": { "1": "green" },
|
||||||
"padding": {
|
"padding": {
|
||||||
"top": 5,
|
"top": 2,
|
||||||
"right": 6
|
"right": 6,
|
||||||
|
"left": 2
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"modules": [
|
"modules": [
|
||||||
@ -60,7 +64,7 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "os",
|
"type": "os",
|
||||||
"key": " OS",
|
"key": " OS",
|
||||||
"keyColor": "yellow"
|
"keyColor": "yellow"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -81,9 +85,15 @@
|
|||||||
"break",
|
"break",
|
||||||
{
|
{
|
||||||
"type": "command",
|
"type": "command",
|
||||||
"key": "│ ├Ø",
|
"key": "Ø Omarchy",
|
||||||
"keyColor": "blue",
|
"keyColor": "blue",
|
||||||
"text": "version=$(git -C ~/.local/share/omarchy describe --tags --abbrev=0 2>/dev/null); echo \"Omarchy $version\""
|
"text": "version=$(git -C ~/.local/share/omarchy describe --tags --abbrev=0 2>/dev/null); echo \"$version\""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "command",
|
||||||
|
"key": "│ ├",
|
||||||
|
"keyColor": "blue",
|
||||||
|
"text": "theme=$(omarchy-theme-current); echo -e \"$theme \\e[38m●\\e[37m●\\e[36m●\\e[35m●\\e[34m●\\e[33m●\\e[32m●\\e[31m●\""
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "de",
|
"type": "de",
|
||||||
|
1
config/fcitx5/conf/xcb.conf
Normal file
1
config/fcitx5/conf/xcb.conf
Normal file
@ -0,0 +1 @@
|
|||||||
|
Allow Overriding System XKB Settings=False
|
@ -1,2 +1,6 @@
|
|||||||
# Extra autostart processes
|
# Extra autostart processes
|
||||||
# exec-once = uwsm app -- my-service
|
# exec-once = uwsm app -- my-service
|
||||||
|
exec-once = [workspace 2 silent] zen-browser
|
||||||
|
exec-once = [workspace 3 silent] thunderbird
|
||||||
|
exec-once = [workspace 4 silent] deltachat-desktop
|
||||||
|
exec-once = [workspace 5 silent] ghostty
|
||||||
|
@ -1,25 +1,18 @@
|
|||||||
# Application bindings
|
# Application bindings
|
||||||
$terminal = uwsm app -- alacritty
|
$terminal = ghostty
|
||||||
$browser = uwsm app -- chromium --new-window --ozone-platform=wayland
|
$browser = omarchy-launch-browser
|
||||||
$webapp = $browser --app
|
|
||||||
|
|
||||||
bindd = SUPER, return, Terminal, exec, $terminal
|
bindd = SUPER, T, 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
|
||||||
bindd = SUPER, N, Neovim, exec, $terminal -e nvim
|
bindd = SUPER, N, Neovim, exec, $terminal -e nvim
|
||||||
bindd = SUPER, T, Activity, exec, $terminal -e btop
|
|
||||||
bindd = SUPER, D, Docker, exec, $terminal -e lazydocker
|
bindd = SUPER, D, Docker, exec, $terminal -e lazydocker
|
||||||
bindd = SUPER, G, Signal, exec, uwsm app -- signal-desktop
|
|
||||||
bindd = SUPER, O, Obsidian, exec, uwsm app -- obsidian -disable-gpu
|
|
||||||
bindd = SUPER, slash, Passwords, exec, uwsm app -- 1password
|
|
||||||
|
|
||||||
bindd = SUPER, A, ChatGPT, exec, $webapp="https://chatgpt.com"
|
# If your web app url contains #, type it as ## to prevent hyperland treat it as comments
|
||||||
bindd = SUPER SHIFT, A, Grok, exec, $webapp="https://grok.com"
|
bindd = SUPER, A, Kagi Assistant, exec, omarchy-launch-webapp "https://kagi.com/assistant"
|
||||||
bindd = SUPER, C, Calendar, exec, $webapp="https://app.hey.com/calendar/weeks/"
|
bindd = SUPER, Y, YouTube, exec, omarchy-launch-webapp "https://youtube.com/"
|
||||||
bindd = SUPER, E, Email, exec, $webapp="https://app.hey.com"
|
|
||||||
bindd = SUPER, Y, YouTube, exec, $webapp="https://youtube.com/"
|
# Overwrite existing bindings, like putting Omarchy Menu on Super + Space
|
||||||
bindd = SUPER SHIFT, G, WhatsApp, exec, $webapp="https://web.whatsapp.com/"
|
# unbind = SUPER, Space
|
||||||
bindd = SUPER ALT, G, Google Messages, exec, $webapp="https://messages.google.com/web/conversations"
|
# bindd = SUPER, SPACE, Omarchy menu, exec, omarchy-menu
|
||||||
bindd = SUPER, X, X, exec, $webapp="https://x.com/"
|
|
||||||
bindd = SUPER SHIFT, X, X Post, exec, $webapp="https://x.com/compose/post"
|
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
general {
|
general {
|
||||||
lock_cmd = pidof hyprlock || hyprlock # avoid starting multiple hyprlock instances.
|
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_lock_cmd = pkill -f "alacritty --class Screensaver" # avoid running screensaver when locked
|
|
||||||
on_unlock_cmd = omarchy-restart-waybar # prevent stacking of waybar when waking
|
on_unlock_cmd = omarchy-restart-waybar # prevent stacking of waybar when waking
|
||||||
|
inhibit_sleep = 3 # wait until screen is locked
|
||||||
}
|
}
|
||||||
|
|
||||||
listener {
|
listener {
|
||||||
|
@ -17,3 +17,8 @@ source = ~/.config/hypr/input.conf
|
|||||||
source = ~/.config/hypr/bindings.conf
|
source = ~/.config/hypr/bindings.conf
|
||||||
source = ~/.config/hypr/envs.conf
|
source = ~/.config/hypr/envs.conf
|
||||||
source = ~/.config/hypr/autostart.conf
|
source = ~/.config/hypr/autostart.conf
|
||||||
|
|
||||||
|
# NVIDIA environment variables
|
||||||
|
env = NVD_BACKEND,direct
|
||||||
|
env = LIBVA_DRIVER_NAME,nvidia
|
||||||
|
env = __GLX_VENDOR_LIBRARY_NAME,nvidia
|
||||||
|
@ -1,37 +1,85 @@
|
|||||||
source = ~/.config/omarchy/current/theme/hyprlock.conf
|
|
||||||
|
|
||||||
|
$accent = rgb(94e2d5)
|
||||||
|
$accentAlpha = 94e2d5
|
||||||
|
$red = rgb(f38ba8)
|
||||||
|
$redAlpha = f38ba8
|
||||||
|
$yellow = rgb(f9e2af)
|
||||||
|
$yellowAlpha = f9e2af
|
||||||
|
$surface0 = rgb(313244)
|
||||||
|
$surface0Alpha = 313244
|
||||||
|
$text = rgb(ffffff)
|
||||||
|
$base = rgb(000000)
|
||||||
|
$font = CaskaydiaMono Nerd Font
|
||||||
|
# GENERAL
|
||||||
|
general {
|
||||||
|
disable_loading_bar = true
|
||||||
|
hide_cursor = true
|
||||||
|
}
|
||||||
|
|
||||||
|
# BACKGROUND
|
||||||
background {
|
background {
|
||||||
monitor =
|
monitor =
|
||||||
color = $color
|
path = ~/.config/omarchy/current/background
|
||||||
|
blur_passes = 2
|
||||||
|
color = $base
|
||||||
}
|
}
|
||||||
|
|
||||||
animations {
|
# TIME
|
||||||
enabled = false
|
label {
|
||||||
}
|
|
||||||
|
|
||||||
input-field {
|
|
||||||
monitor =
|
monitor =
|
||||||
size = 600, 100
|
text = cmd[update:30000] echo "$(date +"%R")"
|
||||||
position = 0, 0
|
color = $text
|
||||||
|
font_size = 90
|
||||||
|
font_family = $font
|
||||||
|
position = -30, 0
|
||||||
|
halign = right
|
||||||
|
valign = top
|
||||||
|
}
|
||||||
|
|
||||||
|
# DATE
|
||||||
|
label {
|
||||||
|
monitor =
|
||||||
|
text = cmd[update:43200000] echo "$(date +"%A, %d %B %Y")"
|
||||||
|
color = $text
|
||||||
|
font_size = 25
|
||||||
|
font_family = $font
|
||||||
|
position = -30, -150
|
||||||
|
halign = right
|
||||||
|
valign = top
|
||||||
|
}
|
||||||
|
|
||||||
|
# USER AVATAR
|
||||||
|
|
||||||
|
image {
|
||||||
|
monitor =
|
||||||
|
path = ~/.face
|
||||||
|
size = 100
|
||||||
|
border_color = $accent
|
||||||
|
|
||||||
|
position = 0, 75
|
||||||
halign = center
|
halign = center
|
||||||
valign = center
|
valign = center
|
||||||
|
}
|
||||||
|
|
||||||
inner_color = $inner_color
|
# INPUT FIELD
|
||||||
outer_color = $outer_color
|
input-field {
|
||||||
|
monitor =
|
||||||
|
size = 300, 60
|
||||||
outline_thickness = 4
|
outline_thickness = 4
|
||||||
|
dots_size = 0.2
|
||||||
font_family = CaskaydiaMono Nerd Font
|
dots_spacing = 0.2
|
||||||
font_color = $font_color
|
dots_center = true
|
||||||
|
outer_color = $accent
|
||||||
placeholder_text = Enter Password
|
inner_color = $surface0
|
||||||
check_color = $check_color
|
font_color = $text
|
||||||
fail_text = <i>$PAMFAIL ($ATTEMPTS)</i>
|
|
||||||
|
|
||||||
rounding = 0
|
|
||||||
shadow_passes = 0
|
|
||||||
fade_on_empty = false
|
fade_on_empty = false
|
||||||
}
|
placeholder_text =
|
||||||
|
hide_input = false
|
||||||
auth {
|
check_color = $accent
|
||||||
fingerprint:enabled = true
|
fail_color = $red
|
||||||
|
fail_text = <i>$FAIL <b>($ATTEMPTS)</b></i>
|
||||||
|
capslock_color = $yellow
|
||||||
|
position = 0, -35
|
||||||
|
halign = center
|
||||||
|
valign = center
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
# Control your input devices
|
# Control your input devices
|
||||||
# See https://wiki.hypr.land/Configuring/Variables/#input
|
# See https://wiki.hypr.land/Configuring/Variables/#input
|
||||||
input {
|
input {
|
||||||
# Use multiple keyboard layouts and switch between them with Alt + Space
|
# Use multiple keyboard layouts and switch between them with Left Alt + Right Alt
|
||||||
# kb_layout = us,dk
|
# kb_layout = us,dk,eu
|
||||||
kb_options = compose:caps # ,grp:alt_space_toggle
|
kb_options = compose:caps # ,grp:alts_toggle
|
||||||
|
|
||||||
# Change speed of keyboard repeat
|
# Change speed of keyboard repeat
|
||||||
repeat_rate = 40
|
repeat_rate = 40
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
# Optimized for retina-class 2x displays, like 13" 2.8K, 27" 5K, 32" 6K.
|
# Optimized for retina-class 2x displays, like 13" 2.8K, 27" 5K, 32" 6K.
|
||||||
env = GDK_SCALE,2
|
env = GDK_SCALE,2
|
||||||
monitor=,preferred,auto,auto
|
monitor=,preferred,auto-right,auto
|
||||||
|
|
||||||
# Good compromise for 27" or 32" 4K monitors (but fractional!)
|
# Good compromise for 27" or 32" 4K monitors (but fractional!)
|
||||||
# env = GDK_SCALE,1.75
|
# env = GDK_SCALE,1.75
|
||||||
|
BIN
config/omarchy.ttf
Normal file
BIN
config/omarchy.ttf
Normal file
Binary file not shown.
32
config/starship.toml
Normal file
32
config/starship.toml
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
add_newline = true
|
||||||
|
command_timeout = 200
|
||||||
|
format = "[$directory$git_branch$git_status]($style)$character"
|
||||||
|
|
||||||
|
[character]
|
||||||
|
error_symbol = "[✗](bold cyan)"
|
||||||
|
success_symbol = "[❯](bold cyan)"
|
||||||
|
|
||||||
|
[directory]
|
||||||
|
truncation_length = 2
|
||||||
|
truncation_symbol = "…/"
|
||||||
|
repo_root_style = "bold cyan"
|
||||||
|
repo_root_format = "[$repo_root]($repo_root_style)[$path]($style)[$read_only]($read_only_style) "
|
||||||
|
|
||||||
|
[git_branch]
|
||||||
|
format = "[$branch]($style) "
|
||||||
|
style = "italic cyan"
|
||||||
|
|
||||||
|
[git_status]
|
||||||
|
format = '[$all_status]($style)'
|
||||||
|
style = "cyan"
|
||||||
|
ahead = "⇡${count} "
|
||||||
|
diverged = "⇕⇡${ahead_count}⇣${behind_count} "
|
||||||
|
behind = "⇣${count} "
|
||||||
|
conflicted = " "
|
||||||
|
up_to_date = " "
|
||||||
|
untracked = "? "
|
||||||
|
modified = " "
|
||||||
|
stashed = ""
|
||||||
|
staged = ""
|
||||||
|
renamed = ""
|
||||||
|
deleted = ""
|
@ -9,7 +9,7 @@ window {
|
|||||||
}
|
}
|
||||||
|
|
||||||
label {
|
label {
|
||||||
font-family: 'CaskaydiaMono Nerd Font', monospace;
|
font-family: 'CaskaydiaMono Nerd Font';
|
||||||
font-size: 11pt;
|
font-size: 11pt;
|
||||||
|
|
||||||
color: @label;
|
color: @label;
|
||||||
|
7
config/uwsm/env
Normal file
7
config/uwsm/env
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
export OMARCHY_PATH=$HOME/.local/share/omarchy
|
||||||
|
export PATH=$OMARCHY_PATH/bin/:$PATH
|
||||||
|
export TERMINAL=alacritty
|
||||||
|
|
||||||
|
if command -v mise &> /dev/null; then
|
||||||
|
eval "$(mise activate bash)"
|
||||||
|
fi
|
@ -1,82 +1,31 @@
|
|||||||
app_launch_prefix = "uwsm app -- "
|
close_when_open = true
|
||||||
terminal_title_flag = ""
|
|
||||||
locale = ""
|
|
||||||
close_when_open = true # Toggle on reopen
|
|
||||||
theme = "omarchy-default"
|
theme = "omarchy-default"
|
||||||
theme_base = []
|
theme_base = []
|
||||||
theme_location = ["~/.local/share/omarchy/default/walker/themes/"]
|
theme_location = ["~/.local/share/omarchy/default/walker/themes/"]
|
||||||
monitor = ""
|
|
||||||
hotreload_theme = true
|
hotreload_theme = true
|
||||||
as_window = false
|
|
||||||
timeout = 0
|
|
||||||
disable_click_to_close = false
|
|
||||||
force_keyboard_focus = true
|
force_keyboard_focus = true
|
||||||
|
timeout = 60
|
||||||
[keys]
|
|
||||||
accept_typeahead = ["tab"]
|
|
||||||
trigger_labels = "lalt"
|
|
||||||
next = ["down"]
|
|
||||||
prev = ["up"]
|
|
||||||
close = ["esc"]
|
|
||||||
remove_from_history = ["shift backspace"]
|
|
||||||
resume_query = ["ctrl r"]
|
|
||||||
toggle_exact_search = ["ctrl m"]
|
|
||||||
|
|
||||||
[keys.activation_modifiers]
|
|
||||||
keep_open = "shift"
|
|
||||||
alternate = "alt"
|
|
||||||
|
|
||||||
[keys.ai]
|
[keys.ai]
|
||||||
clear_session = ["ctrl x"]
|
run_last_response = ["ctrl e"]
|
||||||
copy_last_response = ["ctrl c"]
|
|
||||||
resume_session = ["ctrl r"]
|
|
||||||
run_last_responstruee = ["ctrl e"]
|
|
||||||
|
|
||||||
[events]
|
|
||||||
on_activate = ""
|
|
||||||
on_selection = ""
|
|
||||||
on_exit = ""
|
|
||||||
on_launch = ""
|
|
||||||
on_query_change = ""
|
|
||||||
|
|
||||||
[list]
|
[list]
|
||||||
dynamic_sub = true
|
|
||||||
keyboard_scroll_style = "emacs"
|
|
||||||
max_entries = 200
|
max_entries = 200
|
||||||
show_initial_entries = true
|
cycle = true
|
||||||
single_click = true
|
|
||||||
visibility_threshold = 20
|
|
||||||
placeholder = "No Results"
|
|
||||||
|
|
||||||
[search]
|
[search]
|
||||||
argument_delimiter = "#"
|
|
||||||
placeholder = " Search..."
|
placeholder = " Search..."
|
||||||
delay = 0
|
|
||||||
resume_last_query = false
|
|
||||||
|
|
||||||
[activation_mode]
|
|
||||||
labels = "jkl;asdf"
|
|
||||||
|
|
||||||
[builtins.hyprland_keybinds]
|
[builtins.hyprland_keybinds]
|
||||||
show_sub_when_single = true
|
|
||||||
path = "~/.config/hypr/hyprland.conf"
|
path = "~/.config/hypr/hyprland.conf"
|
||||||
weight = 5
|
|
||||||
name = "hyprland_keybinds"
|
|
||||||
placeholder = "Hyprland Keybinds"
|
|
||||||
switcher_only = true
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.applications]
|
[builtins.applications]
|
||||||
weight = 5
|
launch_prefix = "uwsm app -- "
|
||||||
name = "applications"
|
|
||||||
placeholder = " Search..."
|
placeholder = " Search..."
|
||||||
prioritize_new = false
|
prioritize_new = false
|
||||||
hide_actions_with_empty_query = true
|
|
||||||
context_aware = false
|
context_aware = false
|
||||||
refresh = true
|
|
||||||
show_sub_when_single = false
|
show_sub_when_single = false
|
||||||
show_icon_when_single = true
|
|
||||||
show_generic = true
|
|
||||||
history = false
|
history = false
|
||||||
icon = ""
|
icon = ""
|
||||||
hidden = true
|
hidden = true
|
||||||
@ -84,21 +33,10 @@ hidden = true
|
|||||||
[builtins.applications.actions]
|
[builtins.applications.actions]
|
||||||
enabled = false
|
enabled = false
|
||||||
hide_category = true
|
hide_category = true
|
||||||
hide_without_query = true
|
|
||||||
|
|
||||||
[builtins.bookmarks]
|
[builtins.bookmarks]
|
||||||
weight = 5
|
|
||||||
placeholder = "Bookmarks"
|
|
||||||
name = "bookmarks"
|
|
||||||
icon = "bookmark"
|
|
||||||
switcher_only = true
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[[builtins.bookmarks.entries]]
|
|
||||||
label = "Walker"
|
|
||||||
url = "https://github.com/abenz1267/walker"
|
|
||||||
keywords = ["walker", "github"]
|
|
||||||
|
|
||||||
[[builtins.bookmarks.entries]]
|
[[builtins.bookmarks.entries]]
|
||||||
label = "Omarchy - Github"
|
label = "Omarchy - Github"
|
||||||
url = "https://github.com/basecamp/omarchy"
|
url = "https://github.com/basecamp/omarchy"
|
||||||
@ -109,185 +47,54 @@ label = "Omarchy Manual"
|
|||||||
url = "https://manuals.omamix.org/2/the-omarchy-manual"
|
url = "https://manuals.omamix.org/2/the-omarchy-manual"
|
||||||
keywords = ["omarchy"]
|
keywords = ["omarchy"]
|
||||||
|
|
||||||
[builtins.xdph_picker]
|
|
||||||
hidden = true
|
|
||||||
weight = 5
|
|
||||||
placeholder = "Screen/Window Picker"
|
|
||||||
show_sub_when_single = true
|
|
||||||
name = "xdphpicker"
|
|
||||||
switcher_only = true
|
|
||||||
|
|
||||||
[builtins.ai]
|
|
||||||
weight = 5
|
|
||||||
placeholder = "AI"
|
|
||||||
name = "ai"
|
|
||||||
icon = "help-browser"
|
|
||||||
switcher_only = true
|
|
||||||
show_sub_when_single = true
|
|
||||||
|
|
||||||
[[builtins.ai.anthropic.prompts]]
|
|
||||||
model = "claude-3-7-sonnet-20250219"
|
|
||||||
temperature = 1
|
|
||||||
max_tokens = 1_000
|
|
||||||
label = "General Assistant"
|
|
||||||
prompt = "You are a helpful general assistant. Keep your answers short and precise."
|
|
||||||
|
|
||||||
[builtins.calc]
|
[builtins.calc]
|
||||||
require_number = true
|
|
||||||
weight = 5
|
|
||||||
name = "Calculator"
|
name = "Calculator"
|
||||||
icon = "accessories-calculator"
|
icon = ""
|
||||||
placeholder = "Calculator"
|
min_chars = 3
|
||||||
min_chars = 3 # Min chars to calculate. 3 allows "3+3"
|
|
||||||
prefix = "="
|
prefix = "="
|
||||||
|
|
||||||
[builtins.windows]
|
[builtins.windows]
|
||||||
weight = 5
|
|
||||||
icon = "view-restore"
|
|
||||||
name = "windows"
|
|
||||||
placeholder = "Windows"
|
|
||||||
show_icon_when_single = true
|
|
||||||
switcher_only = true
|
switcher_only = true
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.clipboard]
|
[builtins.clipboard]
|
||||||
always_put_new_on_top = true
|
|
||||||
exec = "wl-copy"
|
|
||||||
weight = 5
|
|
||||||
name = "clipboard"
|
|
||||||
avoid_line_breaks = true
|
|
||||||
placeholder = "Clipboard"
|
|
||||||
image_height = 300
|
|
||||||
max_entries = 10
|
|
||||||
switcher_only = true
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.commands]
|
[builtins.commands]
|
||||||
weight = 5
|
|
||||||
icon = "utilities-terminal"
|
|
||||||
switcher_only = true
|
|
||||||
name = "commands"
|
|
||||||
placeholder = "Commands"
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.custom_commands]
|
[builtins.custom_commands]
|
||||||
weight = 5
|
|
||||||
icon = "utilities-terminal"
|
|
||||||
name = "custom_commands"
|
|
||||||
placeholder = "Custom Commands"
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.emojis]
|
[builtins.emojis]
|
||||||
exec = "wl-copy"
|
|
||||||
weight = 5
|
|
||||||
name = "Emojis"
|
name = "Emojis"
|
||||||
placeholder = "Emojis"
|
icon = ""
|
||||||
switcher_only = true
|
|
||||||
history = true
|
|
||||||
typeahead = true
|
|
||||||
show_unqualified = false
|
|
||||||
prefix = ":"
|
prefix = ":"
|
||||||
|
|
||||||
[builtins.symbols]
|
[builtins.symbols]
|
||||||
after_copy = ""
|
after_copy = ""
|
||||||
weight = 5
|
|
||||||
name = "symbols"
|
|
||||||
placeholder = "Symbols"
|
|
||||||
switcher_only = true
|
|
||||||
history = true
|
|
||||||
typeahead = true
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.finder]
|
[builtins.finder]
|
||||||
use_fd = true
|
use_fd = true
|
||||||
fd_flags = "--ignore-vcs --type file --type directory"
|
|
||||||
cmd_alt = "xdg-open $(dirname ~/%RESULT%)"
|
cmd_alt = "xdg-open $(dirname ~/%RESULT%)"
|
||||||
weight = 5
|
|
||||||
icon = "file"
|
icon = "file"
|
||||||
name = "Finder"
|
name = "Finder"
|
||||||
placeholder = "Finder"
|
|
||||||
switcher_only = true
|
|
||||||
ignore_gitignore = true
|
|
||||||
refresh = true
|
|
||||||
concurrency = 8
|
|
||||||
show_icon_when_single = true
|
|
||||||
preview_images = true
|
preview_images = true
|
||||||
hidden = false
|
hidden = false
|
||||||
prefix = "."
|
prefix = "."
|
||||||
|
|
||||||
[builtins.runner]
|
[builtins.runner]
|
||||||
eager_loading = true
|
shell_config = ""
|
||||||
weight = 5
|
|
||||||
icon = "utilities-terminal"
|
|
||||||
name = "runner"
|
|
||||||
placeholder = "Runner"
|
|
||||||
typeahead = true
|
|
||||||
history = true
|
|
||||||
generic_entry = false # Generic command runner
|
|
||||||
shell_config = "" # Path to shell to parse for aliases
|
|
||||||
refresh = true
|
|
||||||
use_fd = false
|
|
||||||
switcher_only = true
|
switcher_only = true
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.ssh]
|
[builtins.ssh]
|
||||||
weight = 5
|
|
||||||
icon = "preferences-system-network"
|
|
||||||
name = "ssh"
|
|
||||||
placeholder = "SSH"
|
|
||||||
switcher_only = true
|
|
||||||
history = true
|
|
||||||
refresh = true
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[builtins.switcher]
|
|
||||||
weight = 5
|
|
||||||
name = "switcher"
|
|
||||||
placeholder = "Switcher"
|
|
||||||
prefix = "/"
|
|
||||||
|
|
||||||
[builtins.websearch]
|
[builtins.websearch]
|
||||||
keep_selection = true
|
|
||||||
weight = 5
|
|
||||||
icon = "applications-internet"
|
|
||||||
name = "websearch"
|
|
||||||
placeholder = "Websearch"
|
|
||||||
switcher_only = true
|
switcher_only = true
|
||||||
hidden = true
|
hidden = true
|
||||||
|
|
||||||
[[builtins.websearch.entries]]
|
|
||||||
name = "Google"
|
|
||||||
url = "https://www.google.com/search?q=%TERM%"
|
|
||||||
|
|
||||||
[[builtins.websearch.entries]]
|
|
||||||
name = "DuckDuckGo"
|
|
||||||
url = "https://duckduckgo.com/?q=%TERM%"
|
|
||||||
switcher_only = true
|
|
||||||
|
|
||||||
[[builtins.websearch.entries]]
|
|
||||||
name = "Ecosia"
|
|
||||||
url = "https://www.ecosia.org/search?q=%TERM%"
|
|
||||||
switcher_only = true
|
|
||||||
|
|
||||||
[[builtins.websearch.entries]]
|
|
||||||
name = "Yandex"
|
|
||||||
url = "https://yandex.com/search/?text=%TERM%"
|
|
||||||
switcher_only = true
|
|
||||||
|
|
||||||
[builtins.dmenu]
|
|
||||||
hidden = true
|
|
||||||
weight = 5
|
|
||||||
name = "dmenu"
|
|
||||||
placeholder = "Dmenu"
|
|
||||||
switcher_only = true
|
|
||||||
show_icon_when_single = true
|
|
||||||
|
|
||||||
[builtins.translation]
|
[builtins.translation]
|
||||||
delay = 1000
|
|
||||||
weight = 5
|
|
||||||
name = "translation"
|
|
||||||
icon = "accessories-dictionary"
|
|
||||||
placeholder = "Translation"
|
|
||||||
switcher_only = true
|
|
||||||
provider = "googlefree"
|
|
||||||
hidden = true
|
hidden = true
|
||||||
|
@ -4,14 +4,8 @@
|
|||||||
"position": "top",
|
"position": "top",
|
||||||
"spacing": 0,
|
"spacing": 0,
|
||||||
"height": 26,
|
"height": 26,
|
||||||
"modules-left": [
|
"modules-left": ["custom/omarchy", "hyprland/workspaces"],
|
||||||
"custom/omarchy",
|
"modules-center": ["clock", "custom/update"],
|
||||||
"hyprland/workspaces"
|
|
||||||
],
|
|
||||||
"modules-center": [
|
|
||||||
"clock",
|
|
||||||
"custom/update"
|
|
||||||
],
|
|
||||||
"modules-right": [
|
"modules-right": [
|
||||||
"group/tray-expander",
|
"group/tray-expander",
|
||||||
"bluetooth",
|
"bluetooth",
|
||||||
@ -45,16 +39,18 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"custom/omarchy": {
|
"custom/omarchy": {
|
||||||
"format": "",
|
"format": "<span font='omarchy'>\ue900</span>",
|
||||||
"on-click": "~/.local/share/omarchy/bin/omarchy-menu",
|
"on-click": "omarchy-menu",
|
||||||
"tooltip-format": "SUPER + ALT + SPACE"
|
"tooltip-format": "Omarchy Menu\n\nSuper + Alt + Space"
|
||||||
},
|
},
|
||||||
"custom/update": {
|
"custom/update": {
|
||||||
"format": "",
|
"format": "",
|
||||||
"exec": "~/.local/share/omarchy/bin/omarchy-update-available",
|
"exec": "omarchy-update-available",
|
||||||
"on-click": "alacritty --class Omarchy --title Omarchy -e omarchy-update",
|
"on-click": "alacritty --class Omarchy --title Omarchy -e omarchy-update",
|
||||||
|
"tooltip-format": "Omarchy update available",
|
||||||
"interval": 3600
|
"interval": 3600
|
||||||
},
|
},
|
||||||
|
|
||||||
"cpu": {
|
"cpu": {
|
||||||
"interval": 5,
|
"interval": 5,
|
||||||
"format": "",
|
"format": "",
|
||||||
@ -64,19 +60,19 @@
|
|||||||
"format": "{:%A %H:%M}",
|
"format": "{:%A %H:%M}",
|
||||||
"format-alt": "{:%d %B W%V %Y}",
|
"format-alt": "{:%d %B W%V %Y}",
|
||||||
"tooltip": false,
|
"tooltip": false,
|
||||||
"on-click-right": "~/.local/share/omarchy/bin/omarchy-cmd-tzupdate"
|
"on-click-right": "omarchy-cmd-tzupdate"
|
||||||
},
|
},
|
||||||
"network": {
|
"network": {
|
||||||
"format-icons": ["","","","",""],
|
"format-icons": ["", "", "", "", ""],
|
||||||
"format" : "{icon}",
|
"format": "{icon}",
|
||||||
"format-wifi" : "{icon}",
|
"format-wifi": "{icon}",
|
||||||
"format-ethernet" : "",
|
"format-ethernet": "",
|
||||||
"format-disconnected" : "",
|
"format-disconnected": "",
|
||||||
"tooltip-format-wifi": "{essid} ({frequency} GHz)\n⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
"tooltip-format-wifi": "{essid} ({frequency} GHz)\n⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
||||||
"tooltip-format-ethernet": "⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
"tooltip-format-ethernet": "⇣{bandwidthDownBytes} ⇡{bandwidthUpBytes}",
|
||||||
"tooltip-format-disconnected": "Disconnected",
|
"tooltip-format-disconnected": "Disconnected",
|
||||||
"interval": 3,
|
"interval": 3,
|
||||||
"nospacing": 1,
|
"spacing": 1,
|
||||||
"on-click": "alacritty --class=Impala -e impala"
|
"on-click": "alacritty --class=Impala -e impala"
|
||||||
},
|
},
|
||||||
"battery": {
|
"battery": {
|
||||||
@ -85,12 +81,8 @@
|
|||||||
"format-charging": "{icon}",
|
"format-charging": "{icon}",
|
||||||
"format-plugged": "",
|
"format-plugged": "",
|
||||||
"format-icons": {
|
"format-icons": {
|
||||||
"charging": [
|
"charging": ["", "", "", "", "", "", "", "", "", ""],
|
||||||
"", "", "", "", "", "", "", "", "", ""
|
"default": ["", "", "", "", "", "", "", "", "", ""]
|
||||||
],
|
|
||||||
"default": [
|
|
||||||
"", "", "", "", "", "", "", "", "", ""
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"format-full": "",
|
"format-full": "",
|
||||||
"tooltip-format-discharging": "{power:>1.0f}W↓ {capacity}%",
|
"tooltip-format-discharging": "{power:>1.0f}W↓ {capacity}%",
|
||||||
@ -125,10 +117,7 @@
|
|||||||
"transition-duration": 600,
|
"transition-duration": 600,
|
||||||
"children-class": "tray-group-item"
|
"children-class": "tray-group-item"
|
||||||
},
|
},
|
||||||
"modules": [
|
"modules": ["custom/expand-icon", "tray"]
|
||||||
"custom/expand-icon",
|
|
||||||
"tray"
|
|
||||||
]
|
|
||||||
},
|
},
|
||||||
"custom/expand-icon": {
|
"custom/expand-icon": {
|
||||||
"format": " ",
|
"format": " ",
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
border: none;
|
border: none;
|
||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
min-height: 0;
|
min-height: 0;
|
||||||
font-family: CaskaydiaMono Nerd Font Propo;
|
font-family: CaskaydiaMono Nerd Font;
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -36,16 +36,28 @@
|
|||||||
#network,
|
#network,
|
||||||
#bluetooth,
|
#bluetooth,
|
||||||
#pulseaudio,
|
#pulseaudio,
|
||||||
#clock,
|
#custom-omarchy,
|
||||||
#custom-omarchy {
|
#custom-update {
|
||||||
min-width: 12px;
|
min-width: 12px;
|
||||||
margin: 0 7.5px;
|
margin: 0 7.5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#custom-expand-icon {
|
#custom-expand-icon {
|
||||||
margin-right: 12px;
|
margin-right: 7px;
|
||||||
}
|
}
|
||||||
|
|
||||||
tooltip {
|
tooltip {
|
||||||
padding: 2px;
|
padding: 2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#custom-update {
|
||||||
|
font-size: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#clock {
|
||||||
|
margin-left: 8.75px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hidden {
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user