Compare commits
104 Commits
quickshell
...
f07598688f
| Author | SHA1 | Date | |
|---|---|---|---|
|
f07598688f
|
|||
|
e696472c5b
|
|||
|
dcfd134a4e
|
|||
|
77d0a1c449
|
|||
|
7b1044214f
|
|||
|
faba8a05e6
|
|||
|
1eaee50e82
|
|||
|
763c55b68e
|
|||
|
95fc23da50
|
|||
|
a6006d362d
|
|||
|
57cc21a1cd
|
|||
|
e78a3af90c
|
|||
|
3652579508
|
|||
|
1036d4ce0b
|
|||
|
354525129e
|
|||
|
7e9875ac38
|
|||
|
a9089d81b1
|
|||
|
d61cd261e0
|
|||
|
3f206e08c2
|
|||
|
2677ed4594
|
|||
|
905274fe73
|
|||
|
23b30d3a84
|
|||
|
5bead3c20f
|
|||
|
dd2f880a3b
|
|||
|
1869ae86f1
|
|||
|
b7d6cd3dbf
|
|||
|
900b66796b
|
|||
|
44a479d6b4
|
|||
|
b5dca35878
|
|||
|
a1fa09008b
|
|||
|
375c9b59b9
|
|||
|
90f0b4aa63
|
|||
|
fba506e06d
|
|||
|
8b303fb0f0
|
|||
|
49bbfe094a
|
|||
|
3c5c96d623
|
|||
|
5a5fb9a426
|
|||
|
82ba9038ed
|
|||
|
d22d597cf1
|
|||
|
c61b1e8961
|
|||
|
475acb7fd1
|
|||
|
3ef2f7da09
|
|||
|
fbc5a9ee8e
|
|||
|
f46ad8a2f3
|
|||
|
c14a3682ff
|
|||
|
f4a0e2a862
|
|||
|
df589d6797
|
|||
|
1da80c49db
|
|||
|
8080d174ae
|
|||
|
0d39e2869b
|
|||
|
953952f345
|
|||
|
1f60272f14
|
|||
| e5474ffd29 | |||
| dec6db7e8e | |||
| a966a7e81f | |||
| 67b27c4079 | |||
| e958163479 | |||
| 90cd4bdd84 | |||
| e1e3e96626 | |||
| 16f11262ff | |||
| a2b63259ed | |||
| ab539b82ca | |||
| 05c2bc3627 | |||
|
464a162703
|
|||
|
8385671c4f
|
|||
|
433e26edaa
|
|||
|
c28d386c29
|
|||
|
a149d2a3df
|
|||
|
ea02f5b023
|
|||
|
bf904ec38a
|
|||
|
c419ac3a30
|
|||
|
244844242f
|
|||
|
f730d8d118
|
|||
|
590343e5eb
|
|||
|
5da17890cb
|
|||
|
52692a4a47
|
|||
|
f2cb379100
|
|||
|
e6a2690baa
|
|||
|
f642f9c9cc
|
|||
|
7d08e1f5ef
|
|||
|
3cb73506f1
|
|||
|
4be7cd0c0f
|
|||
|
2d038b2ae2
|
|||
|
dd8afc8954
|
|||
|
e69600cc77
|
|||
|
17ef457181
|
|||
|
a39b966a91
|
|||
|
a0b044dbc9
|
|||
|
94764e7a5a
|
|||
|
fef786d317
|
|||
|
8ca0a6cc0f
|
|||
|
3263d72b59
|
|||
|
1c7e5b9f05
|
|||
|
1da34bf704
|
|||
|
88107f9fe7
|
|||
|
5d1f622782
|
|||
|
0ed99176ad
|
|||
|
4dddb0e803
|
|||
|
4353f9da34
|
|||
| 66e772ce62 | |||
| 422259838b | |||
| 390e75ce8e | |||
| a3b627359b | |||
| be75d12e9c |
13
.editorconfig
Normal file
13
.editorconfig
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
root = true
|
||||||
|
|
||||||
|
[*]
|
||||||
|
indent_style = space
|
||||||
|
end_of_line = lf
|
||||||
|
charset = utf-8
|
||||||
|
insert_final_newline = false
|
||||||
|
|
||||||
|
[*.{nix,lua,yaml,css}]
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
[Makefile]
|
||||||
|
indent_size = 4
|
||||||
21
.lazy.lua
Normal file
21
.lazy.lua
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
return {
|
||||||
|
{
|
||||||
|
"folke/lazydev.nvim",
|
||||||
|
ft = "lua",
|
||||||
|
opts = {
|
||||||
|
library = {
|
||||||
|
{ path = "${3rd}/luv/library", words = { "vim%.uv" } },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"hrsh7th/nvim-cmp",
|
||||||
|
opts = function(_, opts)
|
||||||
|
opts.sources = opts.sources or {}
|
||||||
|
table.insert(opts.sources, {
|
||||||
|
name = "lazydev",
|
||||||
|
group_index = 0,
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
}
|
||||||
10
.sops.yaml
10
.sops.yaml
@@ -1,13 +1,11 @@
|
|||||||
keys:
|
keys:
|
||||||
- &imxyy-nix age1jf5pg2x6ta8amj40xdy0stvcvrdlkwc2nrwtmkpymu0qclk0eg5qmm9kns
|
- &imxyy-nix ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOEFLUkyeaK8ZPPZdVNEmtx8zvoxi7xqS2Z6oxRBuUPO
|
||||||
- &imxyy-nix-server age1hpgg6psejh4y6jcdd34wxuml75fnweqpe0kh8376yqsctsfn9qxs037kk6
|
- &imxyy-nix-server ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIB28jpN+h5euh3NtdN+A+EtqgIatC22e4i1TPTioKire
|
||||||
- &imxyy-nix-x16 age1r0fv0tagxupfacv0aaxk5ss7sqvswv6kq8tk3x46ndqrj6f5afvqegahxq
|
- &imxyy-nix-x16 ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIMb5G/ieEYBOng66YeyttBQLThyM6W//z2POsNyq4Rw/
|
||||||
- &imxyy-cloudwin age1tp7th3rrv3x0l6jl76n0hjqjp223w2y586pkgr0hcjwdm254jd5shkj6a8
|
|
||||||
creation_rules:
|
creation_rules:
|
||||||
- path_regex: secrets/.*\.(yaml|toml|json|env|dae|txt|conf)$
|
- path_regex: secrets/.*\..*
|
||||||
key_groups:
|
key_groups:
|
||||||
- age:
|
- age:
|
||||||
- *imxyy-nix
|
- *imxyy-nix
|
||||||
- *imxyy-nix-server
|
- *imxyy-nix-server
|
||||||
- *imxyy-nix-x16
|
- *imxyy-nix-x16
|
||||||
- *imxyy-cloudwin
|
|
||||||
|
|||||||
@@ -1,4 +1,8 @@
|
|||||||
{ config, hostname, ... }:
|
{
|
||||||
|
config,
|
||||||
|
hostname,
|
||||||
|
...
|
||||||
|
}:
|
||||||
{
|
{
|
||||||
# I prefer this to the default issue text
|
# I prefer this to the default issue text
|
||||||
# ported from ArchLinux IIRC
|
# ported from ArchLinux IIRC
|
||||||
@@ -11,7 +15,7 @@
|
|||||||
systemd.services."systemd-machine-id-commit".enable = !config.my.persist.enable;
|
systemd.services."systemd-machine-id-commit".enable = !config.my.persist.enable;
|
||||||
|
|
||||||
my = {
|
my = {
|
||||||
home = {
|
hm = {
|
||||||
# nicely reload system units when changing configs
|
# nicely reload system units when changing configs
|
||||||
systemd.user.startServices = "sd-switch";
|
systemd.user.startServices = "sd-switch";
|
||||||
home.stateVersion = "24.11";
|
home.stateVersion = "24.11";
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
host = "127.0.0.1";
|
host = "127.0.0.1";
|
||||||
port = 8089;
|
port = 8089;
|
||||||
package = pkgs.stable.open-webui;
|
package = pkgs.open-webui;
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts."ai.imxyy.top" = {
|
services.caddy.virtualHosts."ai.imxyy.top" = {
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
|
|||||||
@@ -1,13 +1,12 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
lib,
|
|
||||||
pkgs,
|
pkgs,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
sops.secrets.et-imxyy-nix-server-nixremote = {
|
sops.secrets.et-imxyy-nix-server-nixremote = {
|
||||||
sopsFile = sopsRoot + /et-imxyy-nix-server-nixremote.toml;
|
sopsFile = secrets.et-imxyy-nix-server-nixremote;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
environment.systemPackages = [ pkgs.easytier ];
|
environment.systemPackages = [ pkgs.easytier ];
|
||||||
@@ -15,10 +14,8 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix-server-nixremote.path}";
|
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix-server-nixremote.path}";
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Restart = lib.mkOverride 500 "always";
|
Restart = "always";
|
||||||
RestartMaxDelaySec = lib.mkOverride 500 "1m";
|
RestartSec = 30;
|
||||||
RestartSec = lib.mkOverride 500 "100ms";
|
|
||||||
RestartSteps = lib.mkOverride 500 9;
|
|
||||||
User = "root";
|
User = "root";
|
||||||
};
|
};
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
@@ -37,6 +34,7 @@
|
|||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBWOy0QmAyxENg/O5m3cus8U3c9jCLioivwcWsh5/a82 imxyy-hisense-pad"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBWOy0QmAyxENg/O5m3cus8U3c9jCLioivwcWsh5/a82 imxyy-hisense-pad"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIK8pivvE8PMtsOxmccfNhH/4KehDKhBfUfJbQZxo/SZT imxyy-ace5"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIK8pivvE8PMtsOxmccfNhH/4KehDKhBfUfJbQZxo/SZT imxyy-ace5"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKALTBn/QSGcSPgMg0ViSazFcaA0+nEF05EJpjbsI6dE imxyy_soope_@imxyy-cloudwin"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKALTBn/QSGcSPgMg0ViSazFcaA0+nEF05EJpjbsI6dE imxyy_soope_@imxyy-cloudwin"
|
||||||
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIMb5G/ieEYBOng66YeyttBQLThyM6W//z2POsNyq4Rw/ imxyy@imxyy-nix-x16"
|
||||||
|
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIENauvvhVMLsUwH9cPYsvnOg7VCL3a4yEiKm8I524TE efl@efl-nix"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIENauvvhVMLsUwH9cPYsvnOg7VCL3a4yEiKm8I524TE efl@efl-nix"
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -7,26 +7,22 @@
|
|||||||
}
|
}
|
||||||
];
|
];
|
||||||
services.postgresql.ensureDatabases = [ "coder" ];
|
services.postgresql.ensureDatabases = [ "coder" ];
|
||||||
virtualisation.oci-containers = {
|
virtualisation.oci-containers.containers.coder = {
|
||||||
containers = {
|
image = "ghcr.io/coder/coder:latest";
|
||||||
coder = {
|
environment = {
|
||||||
image = "ghcr.io/coder/coder:latest";
|
CODER_ACCESS_URL = "https://coder.imxyy.top";
|
||||||
environment = {
|
CODER_HTTP_ADDRESS = "0.0.0.0:8086";
|
||||||
CODER_ACCESS_URL = "https://coder.imxyy.top";
|
CODER_PG_CONNECTION_URL = "postgresql://coder:coderdatabase@127.0.0.1/coder?sslmode=disable";
|
||||||
CODER_HTTP_ADDRESS = "0.0.0.0:8086";
|
|
||||||
CODER_PG_CONNECTION_URL = "postgresql://coder:coderdatabase@127.0.0.1/coder?sslmode=disable";
|
|
||||||
};
|
|
||||||
extraOptions = [
|
|
||||||
"--network=host"
|
|
||||||
"--group-add=${toString config.users.groups.podman.gid}"
|
|
||||||
];
|
|
||||||
volumes = [
|
|
||||||
"/var/lib/coder:/home/coder/.config"
|
|
||||||
"/var/run/docker.sock:/var/run/docker.sock"
|
|
||||||
];
|
|
||||||
ports = [ "8086:8086" ];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
extraOptions = [
|
||||||
|
"--network=host"
|
||||||
|
"--group-add=${toString config.users.groups.podman.gid}"
|
||||||
|
];
|
||||||
|
volumes = [
|
||||||
|
"/var/lib/coder:/home/coder/.config"
|
||||||
|
"/var/run/docker.sock:/var/run/docker.sock"
|
||||||
|
];
|
||||||
|
ports = [ "8086:8086" ];
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts."coder.imxyy.top" = {
|
services.caddy.virtualHosts."coder.imxyy.top" = {
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
|
|||||||
@@ -15,7 +15,6 @@
|
|||||||
./vault.nix
|
./vault.nix
|
||||||
./homepage.nix
|
./homepage.nix
|
||||||
./code.nix
|
./code.nix
|
||||||
./yesplaymusic.nix
|
|
||||||
./ai.nix
|
./ai.nix
|
||||||
./grafana.nix
|
./grafana.nix
|
||||||
./note.nix
|
./note.nix
|
||||||
@@ -23,5 +22,8 @@
|
|||||||
./minio.nix
|
./minio.nix
|
||||||
./build.nix
|
./build.nix
|
||||||
./immich.nix
|
./immich.nix
|
||||||
|
|
||||||
|
./efl.nix
|
||||||
|
./plant.nix
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,5 +5,10 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
dockerCompat = true;
|
dockerCompat = true;
|
||||||
dockerSocket.enable = true;
|
dockerSocket.enable = true;
|
||||||
|
defaultNetwork.settings.dns_enabled = true;
|
||||||
|
};
|
||||||
|
# avoid collision with dnsmasq
|
||||||
|
virtualisation.containers = {
|
||||||
|
containersConf.settings.network.dns_bind_port = 5353;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
54
config/hosts/imxyy-nix-server/efl.nix
Normal file
54
config/hosts/imxyy-nix-server/efl.nix
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
{ config, secrets, ... }:
|
||||||
|
{
|
||||||
|
sops.secrets.efl-tuwunel-env = {
|
||||||
|
sopsFile = secrets.efl-tuwunel;
|
||||||
|
format = "dotenv";
|
||||||
|
};
|
||||||
|
virtualisation.oci-containers.containers = {
|
||||||
|
tuwunel = {
|
||||||
|
image = "jevolk/tuwunel:latest";
|
||||||
|
volumes = [
|
||||||
|
"tuwunel_db:/var/lib/tuwunel"
|
||||||
|
];
|
||||||
|
ports = [ "6167:6167" ];
|
||||||
|
networks = [ "podman" ];
|
||||||
|
environment = {
|
||||||
|
TUWUNEL_SERVER_NAME = "mtx.eflx.top";
|
||||||
|
TUWUNEL_PORT = "6167";
|
||||||
|
TUWUNEL_ADDRESS = "0.0.0.0";
|
||||||
|
TUWUNEL_WELL_KNOWN__SERVER = "mtx.eflx.top:443";
|
||||||
|
TUWUNEL_WELL_KNOWN__CLIENT = "https://mtx.eflx.top";
|
||||||
|
};
|
||||||
|
environmentFiles = [
|
||||||
|
config.sops.secrets.efl-tuwunel-env.path
|
||||||
|
];
|
||||||
|
};
|
||||||
|
mautrix-telegram = {
|
||||||
|
image = "dock.mau.dev/mautrix/telegram:latest";
|
||||||
|
ports = [ "8099:8099" ];
|
||||||
|
networks = [ "podman" ];
|
||||||
|
extraOptions = [ "--ip=10.88.0.254" ];
|
||||||
|
volumes = [ "/var/lib/efl-mautrix-telegram:/data" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
send = {
|
||||||
|
image = "lanol/filecodebox:latest";
|
||||||
|
ports = [ "12345:12345" ];
|
||||||
|
volumes = [ "/var/lib/send:/app/data:rw" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
services.caddy.virtualHosts."mtx.eflx.top" = {
|
||||||
|
extraConfig = ''
|
||||||
|
reverse_proxy :6167 {
|
||||||
|
header_up X-Real-IP {remote_host}
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
services.caddy.virtualHosts."send.eflx.top" = {
|
||||||
|
extraConfig = ''
|
||||||
|
reverse_proxy :12345 {
|
||||||
|
header_up X-Real-IP {remote_host}
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -1,14 +1,10 @@
|
|||||||
{
|
{
|
||||||
virtualisation.oci-containers = {
|
virtualisation.oci-containers.containers.sun-panel = {
|
||||||
containers = {
|
image = "hslr/sun-panel:latest";
|
||||||
sun-panel = {
|
volumes = [
|
||||||
image = "hslr/sun-panel:latest";
|
"/var/lib/sun-panel:/app/conf"
|
||||||
volumes = [
|
];
|
||||||
"/var/lib/sun-panel:/app/conf"
|
ports = [ "8085:3002" ];
|
||||||
];
|
|
||||||
ports = [ "8085:3002" ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts."home.imxyy.top" = {
|
services.caddy.virtualHosts."home.imxyy.top" = {
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
|
|||||||
@@ -1,5 +1,9 @@
|
|||||||
{ ... }:
|
{ ... }:
|
||||||
{
|
{
|
||||||
|
users.users.immich = {
|
||||||
|
home = "/mnt/nas/immich";
|
||||||
|
createHome = true;
|
||||||
|
};
|
||||||
services.immich = {
|
services.immich = {
|
||||||
enable = true;
|
enable = true;
|
||||||
host = "127.0.0.1";
|
host = "127.0.0.1";
|
||||||
|
|||||||
@@ -1,46 +1,104 @@
|
|||||||
{
|
{
|
||||||
services.matrix-synapse = {
|
config,
|
||||||
|
secrets,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
nixpkgs.config.permittedInsecurePackages = [
|
||||||
|
"olm-3.2.16"
|
||||||
|
];
|
||||||
|
sops.secrets.tuwunel-reg-token = {
|
||||||
|
sopsFile = secrets.tuwunel-reg-token;
|
||||||
|
format = "binary";
|
||||||
|
owner = config.services.matrix-tuwunel.user;
|
||||||
|
group = config.services.matrix-tuwunel.group;
|
||||||
|
};
|
||||||
|
sops.secrets.tuwunel-turn-secret = {
|
||||||
|
sopsFile = secrets.tuwunel-turn-secret;
|
||||||
|
format = "binary";
|
||||||
|
owner = config.services.matrix-tuwunel.user;
|
||||||
|
group = config.services.matrix-tuwunel.group;
|
||||||
|
};
|
||||||
|
services.matrix-tuwunel = {
|
||||||
enable = true;
|
enable = true;
|
||||||
settings = {
|
settings.global = {
|
||||||
server_name = "matrix.imxyy.top";
|
address = [ "127.0.0.1" ];
|
||||||
public_baseurl = "https://matrix.imxyy.top";
|
port = [ 8094 ];
|
||||||
listeners = [
|
server_name = "imxyy.top";
|
||||||
{
|
well_known = {
|
||||||
port = 8094;
|
server = "matrix.imxyy.top:443";
|
||||||
bind_addresses = [ "127.0.0.1" ];
|
client = "https://matrix.imxyy.top";
|
||||||
type = "http";
|
};
|
||||||
tls = false;
|
|
||||||
x_forwarded = true;
|
allow_registration = true;
|
||||||
resources = [
|
registration_token_file = config.sops.secrets.tuwunel-reg-token.path;
|
||||||
{
|
|
||||||
names = [
|
suppress_push_when_active = true;
|
||||||
"client"
|
|
||||||
"federation"
|
turn_uris = [
|
||||||
];
|
"turn:hk.vkvm.imxyy.top?transport=udp"
|
||||||
compress = true;
|
"turn:hk.vkvm.imxyy.top?transport=tcp"
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
|
||||||
];
|
];
|
||||||
turn_uris = [ "turns:vkvm.imxyy.top:5349" ];
|
turn_secret_file = config.sops.secrets.tuwunel-turn-secret.path;
|
||||||
turn_shared_secret = "ac779a48c03bb451839569d295a29aa6ab8c264277bec2df9c9c7f5e22936288";
|
|
||||||
turn_user_lifetime = "1h";
|
new_user_displayname_suffix = "";
|
||||||
database_type = "psycopg2";
|
|
||||||
database_args.database = "matrix-synapse";
|
|
||||||
};
|
};
|
||||||
extraConfigFiles = [
|
};
|
||||||
"/var/lib/matrix-synapse/secret"
|
services.caddy.virtualHosts."imxyy.top" = {
|
||||||
];
|
extraConfig = ''
|
||||||
|
handle /.well-known/matrix/server {
|
||||||
|
header Content-Type application/json
|
||||||
|
header "Access-Control-Allow-Origin" "*"
|
||||||
|
|
||||||
|
respond `{"m.server": "matrix.imxyy.top:443"}` 200
|
||||||
|
}
|
||||||
|
handle /.well-known/matrix/client {
|
||||||
|
header Content-Type application/json
|
||||||
|
header "Access-Control-Allow-Origin" "*"
|
||||||
|
|
||||||
|
respond `{"m.homeserver": {"base_url": "https://matrix.imxyy.top/"}}` 200
|
||||||
|
}
|
||||||
|
'';
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts."matrix.imxyy.top" = {
|
services.caddy.virtualHosts."matrix.imxyy.top" = {
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
reverse_proxy :8094
|
reverse_proxy :8094
|
||||||
handle_path /_matrix {
|
|
||||||
reverse_proxy :8094
|
|
||||||
}
|
|
||||||
handle_path /_synapse/client {
|
|
||||||
reverse_proxy :8094
|
|
||||||
}
|
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
sops.secrets.mautrix-telegram = {
|
||||||
|
sopsFile = secrets.mautrix-telegram;
|
||||||
|
format = "dotenv";
|
||||||
|
owner = "mautrix-telegram";
|
||||||
|
group = "mautrix-telegram";
|
||||||
|
};
|
||||||
|
services.mautrix-telegram = {
|
||||||
|
enable = true;
|
||||||
|
environmentFile = config.sops.secrets.mautrix-telegram.path;
|
||||||
|
settings = {
|
||||||
|
homeserver = {
|
||||||
|
address = "http://127.0.0.1:8094";
|
||||||
|
domain = "imxyy.top";
|
||||||
|
};
|
||||||
|
appservice = {
|
||||||
|
address = "http://127.0.0.1:8098";
|
||||||
|
hostname = "127.0.0.1";
|
||||||
|
port = "8098";
|
||||||
|
bot_username = "telegrambot";
|
||||||
|
};
|
||||||
|
bridge = {
|
||||||
|
username_template = "telegram_{userid}";
|
||||||
|
alias_template = "telegram_{groupname}";
|
||||||
|
displayname_template = "{displayname} (Telegram)";
|
||||||
|
permissions = {
|
||||||
|
"@imxyy_soope_:imxyy.top" = "admin";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
telegram = {
|
||||||
|
# borrowed from https://github.com/telegramdesktop/tdesktop/blob/9bdc19e2fd4d497c8f403891848383a88faadc25/snap/snapcraft.yaml#L134-L135
|
||||||
|
api_id = "611335";
|
||||||
|
api_hash = "d524b414d21f4d37f08684c1df41ac9c";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,9 +8,10 @@
|
|||||||
WorkingDirectory = "/opt/minecraft/fabric1.20.6";
|
WorkingDirectory = "/opt/minecraft/fabric1.20.6";
|
||||||
ExecStart = "${lib.getExe' pkgs.openjdk21 "java"} -Xms1G -Xmx5G -jar fabric-server-mc.1.20.6-loader.0.15.11-launcher.1.0.1.jar";
|
ExecStart = "${lib.getExe' pkgs.openjdk21 "java"} -Xms1G -Xmx5G -jar fabric-server-mc.1.20.6-loader.0.15.11-launcher.1.0.1.jar";
|
||||||
Restart = "always";
|
Restart = "always";
|
||||||
RestartSec = "10s";
|
RestartSec = 120;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
my.persist = {
|
my.persist = {
|
||||||
nixosDirs = [
|
nixosDirs = [
|
||||||
"/opt/minecraft"
|
"/opt/minecraft"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{ config, sopsRoot, ... }:
|
{ config, secrets, ... }:
|
||||||
{
|
{
|
||||||
sops.secrets.minio-env = {
|
sops.secrets.minio-env = {
|
||||||
sopsFile = sopsRoot + /minio.env;
|
sopsFile = secrets.minio;
|
||||||
format = "dotenv";
|
format = "dotenv";
|
||||||
};
|
};
|
||||||
services.minio = {
|
services.minio = {
|
||||||
@@ -16,11 +16,4 @@
|
|||||||
];
|
];
|
||||||
rootCredentialsFile = config.sops.secrets.minio-env.path;
|
rootCredentialsFile = config.sops.secrets.minio-env.path;
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts."minio.imxyy.top" = {
|
|
||||||
extraConfig = ''
|
|
||||||
handle_path /* {
|
|
||||||
reverse_proxy :9000
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
lib,
|
lib,
|
||||||
pkgs,
|
pkgs,
|
||||||
username,
|
username,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -131,26 +131,29 @@
|
|||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOEFLUkyeaK8ZPPZdVNEmtx8zvoxi7xqS2Z6oxRBuUPO imxyy@imxyy-nix"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOEFLUkyeaK8ZPPZdVNEmtx8zvoxi7xqS2Z6oxRBuUPO imxyy@imxyy-nix"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBWOy0QmAyxENg/O5m3cus8U3c9jCLioivwcWsh5/a82 imxyy-hisense-pad"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBWOy0QmAyxENg/O5m3cus8U3c9jCLioivwcWsh5/a82 imxyy-hisense-pad"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIK8pivvE8PMtsOxmccfNhH/4KehDKhBfUfJbQZxo/SZT imxyy-ace5"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIK8pivvE8PMtsOxmccfNhH/4KehDKhBfUfJbQZxo/SZT imxyy-ace5"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKALTBn/QSGcSPgMg0ViSazFcaA0+nEF05EJpjbsI6dE imxyy_soope_@imxyy-cloudwin"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIMb5G/ieEYBOng66YeyttBQLThyM6W//z2POsNyq4Rw/ imxyy@imxyy-nix-x16"
|
||||||
];
|
];
|
||||||
users.users.${username}.openssh.authorizedKeys.keys = [
|
users.users.${username}.openssh.authorizedKeys.keys = [
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOEFLUkyeaK8ZPPZdVNEmtx8zvoxi7xqS2Z6oxRBuUPO imxyy@imxyy-nix"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOEFLUkyeaK8ZPPZdVNEmtx8zvoxi7xqS2Z6oxRBuUPO imxyy@imxyy-nix"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBWOy0QmAyxENg/O5m3cus8U3c9jCLioivwcWsh5/a82 imxyy-hisense-pad"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBWOy0QmAyxENg/O5m3cus8U3c9jCLioivwcWsh5/a82 imxyy-hisense-pad"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIK8pivvE8PMtsOxmccfNhH/4KehDKhBfUfJbQZxo/SZT imxyy-ace5"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIK8pivvE8PMtsOxmccfNhH/4KehDKhBfUfJbQZxo/SZT imxyy-ace5"
|
||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKALTBn/QSGcSPgMg0ViSazFcaA0+nEF05EJpjbsI6dE imxyy_soope_@imxyy-cloudwin"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIMb5G/ieEYBOng66YeyttBQLThyM6W//z2POsNyq4Rw/ imxyy@imxyy-nix-x16"
|
||||||
];
|
];
|
||||||
|
|
||||||
sops.secrets.dae-imxyy-nix-server = {
|
sops.secrets.dae-imxyy-nix-server = {
|
||||||
sopsFile = sopsRoot + /dae-imxyy-nix-server.dae;
|
sopsFile = secrets.dae-imxyy-nix-server;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
services.dae = {
|
services.dae = {
|
||||||
enable = true;
|
enable = true;
|
||||||
configFile = config.sops.secrets.dae-imxyy-nix-server.path;
|
configFile = config.sops.secrets.dae-imxyy-nix-server.path;
|
||||||
};
|
};
|
||||||
systemd.services.dae.after = [ "sops-nix.service" ];
|
systemd.services.dae = {
|
||||||
|
after = [ "sops-nix.service" ];
|
||||||
|
serviceConfig.MemoryMax = "1G";
|
||||||
|
};
|
||||||
sops.secrets.mihomo = {
|
sops.secrets.mihomo = {
|
||||||
sopsFile = sopsRoot + /mihomo.yaml;
|
sopsFile = secrets.mihomo;
|
||||||
format = "yaml";
|
format = "yaml";
|
||||||
key = "";
|
key = "";
|
||||||
};
|
};
|
||||||
@@ -162,7 +165,7 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
sops.secrets.frp-env = {
|
sops.secrets.frp-env = {
|
||||||
sopsFile = sopsRoot + /frp.env;
|
sopsFile = secrets.frp;
|
||||||
format = "dotenv";
|
format = "dotenv";
|
||||||
};
|
};
|
||||||
systemd.services.frp.serviceConfig.EnvironmentFile = [
|
systemd.services.frp.serviceConfig.EnvironmentFile = [
|
||||||
@@ -205,20 +208,6 @@
|
|||||||
localPort = 443;
|
localPort = 443;
|
||||||
customDomains = [ "oidc.imxyy.top" ];
|
customDomains = [ "oidc.imxyy.top" ];
|
||||||
}
|
}
|
||||||
{
|
|
||||||
name = "headscale-http";
|
|
||||||
type = "http";
|
|
||||||
localIP = "127.0.0.1";
|
|
||||||
localPort = 80;
|
|
||||||
customDomains = [ "headscale.imxyy.top" ];
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "headscale-https";
|
|
||||||
type = "https";
|
|
||||||
localIP = "127.0.0.1";
|
|
||||||
localPort = 443;
|
|
||||||
customDomains = [ "headscale.imxyy.top" ];
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
name = "mail-http";
|
name = "mail-http";
|
||||||
@@ -302,21 +291,6 @@
|
|||||||
customDomains = [ "coder.imxyy.top" ];
|
customDomains = [ "coder.imxyy.top" ];
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
|
||||||
name = "music-http";
|
|
||||||
type = "http";
|
|
||||||
localIP = "127.0.0.1";
|
|
||||||
localPort = 80;
|
|
||||||
customDomains = [ "music.imxyy.top" ];
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "music-https";
|
|
||||||
type = "https";
|
|
||||||
localIP = "127.0.0.1";
|
|
||||||
localPort = 443;
|
|
||||||
customDomains = [ "music.imxyy.top" ];
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
name = "ai-http";
|
name = "ai-http";
|
||||||
type = "http";
|
type = "http";
|
||||||
@@ -347,21 +321,6 @@
|
|||||||
customDomains = [ "grafana.imxyy.top" ];
|
customDomains = [ "grafana.imxyy.top" ];
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
|
||||||
name = "note-http";
|
|
||||||
type = "http";
|
|
||||||
localIP = "127.0.0.1";
|
|
||||||
localPort = 80;
|
|
||||||
customDomains = [ "note.imxyy.top" ];
|
|
||||||
}
|
|
||||||
{
|
|
||||||
name = "note-https";
|
|
||||||
type = "https";
|
|
||||||
localIP = "127.0.0.1";
|
|
||||||
localPort = 443;
|
|
||||||
customDomains = [ "note.imxyy.top" ];
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
name = "siyuan-http";
|
name = "siyuan-http";
|
||||||
type = "http";
|
type = "http";
|
||||||
@@ -377,6 +336,20 @@
|
|||||||
customDomains = [ "sy.imxyy.top" ];
|
customDomains = [ "sy.imxyy.top" ];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
name = "matrix-root-http";
|
||||||
|
type = "http";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 80;
|
||||||
|
customDomains = [ "imxyy.top" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "matrix-root-https";
|
||||||
|
type = "https";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 443;
|
||||||
|
customDomains = [ "imxyy.top" ];
|
||||||
|
}
|
||||||
{
|
{
|
||||||
name = "matrix-http";
|
name = "matrix-http";
|
||||||
type = "http";
|
type = "http";
|
||||||
@@ -408,63 +381,54 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
name = "minecraft";
|
name = "memo-http";
|
||||||
type = "tcp";
|
type = "http";
|
||||||
localIP = "127.0.0.1";
|
localIP = "127.0.0.1";
|
||||||
localPort = 25565;
|
localPort = 80;
|
||||||
remotePort = 25565;
|
customDomains = [ "memo.imxyy.top" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "memo-https";
|
||||||
|
type = "https";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 443;
|
||||||
|
customDomains = [ "memo.imxyy.top" ];
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
name = "efl-matrix-http";
|
||||||
|
type = "http";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 80;
|
||||||
|
customDomains = [ "mtx.eflx.top" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "efl-matrix-https";
|
||||||
|
type = "https";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 443;
|
||||||
|
customDomains = [ "mtx.eflx.top" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "efl-send-http";
|
||||||
|
type = "http";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 80;
|
||||||
|
customDomains = [ "send.eflx.top" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "efl-send-https";
|
||||||
|
type = "https";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 443;
|
||||||
|
customDomains = [ "send.eflx.top" ];
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
services.tailscale = {
|
|
||||||
enable = true;
|
|
||||||
useRoutingFeatures = "both";
|
|
||||||
extraSetFlags = [ "--accept-dns=false" ];
|
|
||||||
};
|
|
||||||
services.headscale = {
|
|
||||||
enable = true;
|
|
||||||
address = "0.0.0.0";
|
|
||||||
port = 8080;
|
|
||||||
settings = {
|
|
||||||
logtail.enabled = false;
|
|
||||||
server_url = "https://headscale.imxyy.top";
|
|
||||||
dns.magic_dns = false;
|
|
||||||
dns.override_local_dns = false;
|
|
||||||
ip_prefixes = "100.64.0.0/10";
|
|
||||||
|
|
||||||
oidc = {
|
|
||||||
only_start_if_oidc_is_available = true;
|
|
||||||
issuer = "https://oidc.imxyy.top";
|
|
||||||
client_id = "https://headscale.imxyy.top";
|
|
||||||
allowed_domains = [
|
|
||||||
"imxyy.top"
|
|
||||||
"*.imxyy.top"
|
|
||||||
];
|
|
||||||
client_secret = "";
|
|
||||||
expiry = 0;
|
|
||||||
extra_params.domain_hint = "imxyy.top";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
systemd.services."headscale" = {
|
|
||||||
serviceConfig = {
|
|
||||||
Restart = lib.mkOverride 500 "always";
|
|
||||||
RestartMaxDelaySec = lib.mkOverride 500 "1m";
|
|
||||||
RestartSec = lib.mkOverride 500 "100ms";
|
|
||||||
RestartSteps = lib.mkOverride 500 9;
|
|
||||||
};
|
|
||||||
after = [
|
|
||||||
"podman-obligator.service"
|
|
||||||
];
|
|
||||||
requires = [
|
|
||||||
"podman-obligator.service"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
sops.secrets.et-imxyy-nix-server = {
|
sops.secrets.et-imxyy-nix-server = {
|
||||||
sopsFile = sopsRoot + /et-imxyy-nix-server.toml;
|
sopsFile = secrets.et-imxyy-nix-server;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
environment.systemPackages = [ pkgs.easytier ];
|
environment.systemPackages = [ pkgs.easytier ];
|
||||||
@@ -472,10 +436,8 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix-server.path}";
|
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix-server.path}";
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Restart = lib.mkOverride 500 "always";
|
Restart = "always";
|
||||||
RestartMaxDelaySec = lib.mkOverride 500 "1m";
|
RestartSec = 30;
|
||||||
RestartSec = lib.mkOverride 500 "100ms";
|
|
||||||
RestartSteps = lib.mkOverride 500 9;
|
|
||||||
User = "root";
|
User = "root";
|
||||||
};
|
};
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
@@ -485,34 +447,23 @@
|
|||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
virtualisation.oci-containers = {
|
virtualisation.oci-containers.containers.obligator = {
|
||||||
containers = {
|
image = "anderspitman/obligator:latest";
|
||||||
obligator = {
|
volumes = [
|
||||||
image = "anderspitman/obligator:latest";
|
"/var/lib/obligator:/data"
|
||||||
volumes = [
|
"/var/lib/obligator:/api"
|
||||||
"/var/lib/obligator:/data"
|
];
|
||||||
"/var/lib/obligator:/api"
|
ports = [ "8081:1616" ];
|
||||||
];
|
cmd = [
|
||||||
ports = [ "8081:1616" ];
|
"-storage-dir"
|
||||||
cmd = [
|
"/data"
|
||||||
"-storage-dir"
|
"-api-socket-dir"
|
||||||
"/data"
|
"/api"
|
||||||
"-api-socket-dir"
|
"-root-uri"
|
||||||
"/api"
|
"https://oidc.imxyy.top"
|
||||||
"-root-uri"
|
"-port"
|
||||||
"https://oidc.imxyy.top"
|
"1616"
|
||||||
"-port"
|
];
|
||||||
"1616"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
services.caddy.virtualHosts."headscale.imxyy.top" = {
|
|
||||||
extraConfig = ''
|
|
||||||
reverse_proxy :8080 {
|
|
||||||
header_up X-Real-IP {remote_host}
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts."oidc.imxyy.top" = {
|
services.caddy.virtualHosts."oidc.imxyy.top" = {
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
@@ -524,9 +475,10 @@
|
|||||||
|
|
||||||
systemd.services.ddns-go =
|
systemd.services.ddns-go =
|
||||||
let
|
let
|
||||||
ddns-go = pkgs.buildGoModule rec {
|
version = "6.6.7";
|
||||||
|
ddns-go = pkgs.buildGoModule {
|
||||||
|
inherit version;
|
||||||
pname = "ddns-go";
|
pname = "ddns-go";
|
||||||
version = "6.6.7";
|
|
||||||
src = pkgs.fetchFromGitHub {
|
src = pkgs.fetchFromGitHub {
|
||||||
owner = "jeessy2";
|
owner = "jeessy2";
|
||||||
repo = "ddns-go";
|
repo = "ddns-go";
|
||||||
@@ -561,7 +513,6 @@
|
|||||||
"git"
|
"git"
|
||||||
"vault"
|
"vault"
|
||||||
"coder"
|
"coder"
|
||||||
"headscale"
|
|
||||||
"grafana"
|
"grafana"
|
||||||
"matrix"
|
"matrix"
|
||||||
"note"
|
"note"
|
||||||
@@ -570,23 +521,22 @@
|
|||||||
"music"
|
"music"
|
||||||
"ai"
|
"ai"
|
||||||
"sy"
|
"sy"
|
||||||
"minio"
|
"immich"
|
||||||
];
|
];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
enable = true;
|
enable = true;
|
||||||
resolveLocalQueries = false;
|
resolveLocalQueries = false;
|
||||||
settings = {
|
settings = {
|
||||||
server = [
|
no-resolv = true;
|
||||||
"120.53.53.53"
|
server = [ "192.168.3.1" ];
|
||||||
"223.5.5.5"
|
|
||||||
];
|
|
||||||
address = map (sub: "/${sub}.imxyy.top/192.168.3.2") subDomains ++ [
|
address = map (sub: "/${sub}.imxyy.top/192.168.3.2") subDomains ++ [
|
||||||
"/imxyy-nix-server/192.168.3.2"
|
"/imxyy-nix-server/192.168.3.2"
|
||||||
"/imxyy-cloudwin/192.168.3.4"
|
"/imxyy-cloudwin/192.168.3.4"
|
||||||
"/printer.home/192.168.3.53"
|
"/printer.home/192.168.3.53"
|
||||||
];
|
];
|
||||||
cache-size = 0;
|
cache-size = 0;
|
||||||
|
log-queries = "extra";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
lib,
|
lib,
|
||||||
config,
|
config,
|
||||||
username,
|
username,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -13,17 +13,16 @@
|
|||||||
timeout = 0;
|
timeout = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
hardware.bluetooth.enable = true;
|
|
||||||
hardware.bluetooth.powerOnBoot = true;
|
|
||||||
|
|
||||||
systemd.services.nix-daemon = {
|
systemd.services.nix-daemon = {
|
||||||
environment.TMPDIR = "/var/cache/nix";
|
environment.TMPDIR = "/var/cache/nix";
|
||||||
serviceConfig.CacheDirectory = "nix";
|
serviceConfig.CacheDirectory = "nix";
|
||||||
};
|
};
|
||||||
environment.variables.NIX_REMOTE = "daemon";
|
environment.variables.NIX_REMOTE = "daemon";
|
||||||
|
|
||||||
|
my.audio.enable = false;
|
||||||
|
|
||||||
sops.secrets.imxyy-nix-server-hashed-password = {
|
sops.secrets.imxyy-nix-server-hashed-password = {
|
||||||
sopsFile = sopsRoot + /imxyy-nix-server-hashed-password.txt;
|
sopsFile = secrets.imxyy-nix-server-hashed-password;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
neededForUsers = true;
|
neededForUsers = true;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,61 +1,52 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
sops.secrets = {
|
sops.secrets = {
|
||||||
flatnote-env = {
|
|
||||||
sopsFile = sopsRoot + /flatnote.env;
|
|
||||||
format = "dotenv";
|
|
||||||
};
|
|
||||||
siyuan-env = {
|
siyuan-env = {
|
||||||
sopsFile = sopsRoot + /siyuan.env;
|
sopsFile = secrets.siyuan;
|
||||||
format = "dotenv";
|
format = "dotenv";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
virtualisation.oci-containers = {
|
virtualisation.oci-containers.containers = {
|
||||||
containers = {
|
siyuan = {
|
||||||
flatnotes = {
|
image = "apkdv/siyuan-unlock:v3.1.30";
|
||||||
image = "dullage/flatnotes:latest";
|
volumes = [
|
||||||
volumes = [
|
"/mnt/nas/siyuan/workspace:/workspace"
|
||||||
"/mnt/nas/flatnotes/data:/data"
|
"/mnt/nas/siyuan:/home/siyuan"
|
||||||
];
|
];
|
||||||
environmentFiles = [
|
cmd = [
|
||||||
"${config.sops.secrets.flatnote-env.path}"
|
"--workspace=/workspace"
|
||||||
];
|
];
|
||||||
ports = [ "8093:8080" ];
|
environment = {
|
||||||
};
|
PUID = "0";
|
||||||
siyuan = {
|
PGID = "0";
|
||||||
image = "apkdv/siyuan-unlock:v3.1.30";
|
|
||||||
volumes = [
|
|
||||||
"/mnt/nas/siyuan/workspace:/workspace"
|
|
||||||
"/mnt/nas/siyuan:/home/siyuan"
|
|
||||||
];
|
|
||||||
cmd = [
|
|
||||||
"--workspace=/workspace"
|
|
||||||
];
|
|
||||||
environment = {
|
|
||||||
PUID = "0";
|
|
||||||
PGID = "0";
|
|
||||||
};
|
|
||||||
environmentFiles = [
|
|
||||||
"${config.sops.secrets.siyuan-env.path}"
|
|
||||||
];
|
|
||||||
ports = [ "8095:6806" ];
|
|
||||||
};
|
};
|
||||||
|
environmentFiles = [
|
||||||
|
"${config.sops.secrets.siyuan-env.path}"
|
||||||
|
];
|
||||||
|
ports = [ "8095:6806" ];
|
||||||
|
};
|
||||||
|
memos = {
|
||||||
|
image = "neosmemo/memos:stable";
|
||||||
|
volumes = [
|
||||||
|
"/mnt/nas/memos:/var/opt/memos"
|
||||||
|
];
|
||||||
|
ports = [ "8097:5230" ];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
services.caddy.virtualHosts = {
|
services.caddy.virtualHosts = {
|
||||||
"note.imxyy.top" = {
|
|
||||||
extraConfig = ''
|
|
||||||
reverse_proxy :8093
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
"sy.imxyy.top" = {
|
"sy.imxyy.top" = {
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
reverse_proxy :8095
|
reverse_proxy :8095
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
"memo.imxyy.top" = {
|
||||||
|
extraConfig = ''
|
||||||
|
reverse_proxy :8097
|
||||||
|
'';
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
74
config/hosts/imxyy-nix-server/plant.nix
Normal file
74
config/hosts/imxyy-nix-server/plant.nix
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
{
|
||||||
|
inputs,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
app = pkgs.buildNpmPackage (finalAttrs: {
|
||||||
|
pname = "HF-plant";
|
||||||
|
version = "unstable-2025-09-21";
|
||||||
|
|
||||||
|
src = inputs.plant;
|
||||||
|
|
||||||
|
buildPhase = ''
|
||||||
|
runHook preBuild
|
||||||
|
|
||||||
|
npm run build
|
||||||
|
npm run build:proxy
|
||||||
|
|
||||||
|
runHook postBuild
|
||||||
|
'';
|
||||||
|
installPhase = ''
|
||||||
|
runHook preInstall
|
||||||
|
|
||||||
|
mkdir $out
|
||||||
|
mv dist $out
|
||||||
|
cp .env proxy-server-bundled.js $out
|
||||||
|
|
||||||
|
runHook postInstall
|
||||||
|
'';
|
||||||
|
|
||||||
|
npmDepsHash = "sha256-ret4BtjrEt8L1nlvJmFiejAKmbz89Z7NSiKs+qlB51w=";
|
||||||
|
});
|
||||||
|
in
|
||||||
|
{
|
||||||
|
systemd.services.HF-plant-proxy = {
|
||||||
|
after = [ "network.target" ];
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
serviceConfig = {
|
||||||
|
ExecStart = "${lib.getExe pkgs.bash} -c 'source ${app}/.env; export FEISHU_APP_ID FEISHU_APP_SECRET AMAP_JSCODE; ${lib.getExe pkgs.nodejs} ${app}/proxy-server-bundled.js'";
|
||||||
|
Restart = "always";
|
||||||
|
RestartSec = 120;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
services.caddy.virtualHosts."plant.imxyy.top" = {
|
||||||
|
extraConfig = ''
|
||||||
|
handle /api/* {
|
||||||
|
reverse_proxy localhost:3001
|
||||||
|
}
|
||||||
|
|
||||||
|
handle /* {
|
||||||
|
root * ${app}/dist
|
||||||
|
try_files {path} /index.html
|
||||||
|
file_server
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
services.frp.settings.proxies = [
|
||||||
|
{
|
||||||
|
name = "plant-http";
|
||||||
|
type = "http";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 80;
|
||||||
|
customDomains = [ "plant.imxyy.top" ];
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "plant-https";
|
||||||
|
type = "https";
|
||||||
|
localIP = "127.0.0.1";
|
||||||
|
localPort = 443;
|
||||||
|
customDomains = [ "plant.imxyy.top" ];
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
{ config, sopsRoot, ... }:
|
{ config, secrets, ... }:
|
||||||
{
|
{
|
||||||
sops.secrets.vaultwarden-env = {
|
sops.secrets.vaultwarden-env = {
|
||||||
sopsFile = sopsRoot + /vaultwarden.env;
|
sopsFile = secrets.vaultwarden;
|
||||||
format = "dotenv";
|
format = "dotenv";
|
||||||
};
|
};
|
||||||
services.postgresql.ensureUsers = [
|
services.postgresql.ensureUsers = [
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ let
|
|||||||
in
|
in
|
||||||
{
|
{
|
||||||
boot = {
|
boot = {
|
||||||
initrd.kernelModules = [
|
initrd.kernelModules = lib.mkBefore [
|
||||||
"vfio_pci"
|
"vfio_pci"
|
||||||
"vfio"
|
"vfio"
|
||||||
"vfio_iommu_type1"
|
"vfio_iommu_type1"
|
||||||
|
|||||||
@@ -1,23 +0,0 @@
|
|||||||
{
|
|
||||||
virtualisation.oci-containers.containers."YesPlayMusic" = {
|
|
||||||
image = "git.imxyy.top/imxyy1soope1/yesplaymusic:latest";
|
|
||||||
environment = {
|
|
||||||
"NODE_TLS_REJECT_UNAUTHORIZED" = "0";
|
|
||||||
};
|
|
||||||
volumes = [
|
|
||||||
"/etc/localtime:/etc/localtime:ro"
|
|
||||||
];
|
|
||||||
ports = [
|
|
||||||
"8088:80/tcp"
|
|
||||||
];
|
|
||||||
log-driver = "journald";
|
|
||||||
};
|
|
||||||
|
|
||||||
services.caddy.virtualHosts."music.imxyy.top" = {
|
|
||||||
extraConfig = ''
|
|
||||||
reverse_proxy :8088 {
|
|
||||||
header_up X-Real-IP {remote_host}
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
|
||||||
@@ -1,10 +1,10 @@
|
|||||||
{ lib, username, ... }:
|
{ lib, username, ... }:
|
||||||
{
|
{
|
||||||
my.home.programs.zsh.shellAliases = {
|
my.hm.programs.zsh.shellAliases = {
|
||||||
localproxy_on = "export http_proxy=http://192.168.128.1:7890 https_proxy=http://192.168.128.1:7890 all_proxy=socks://192.168.128.1:7890";
|
localproxy_on = "export http_proxy=http://192.168.128.1:7890 https_proxy=http://192.168.128.1:7890 all_proxy=socks://192.168.128.1:7890";
|
||||||
};
|
};
|
||||||
my = {
|
my = {
|
||||||
sops.sshKeyPath = "/home/${username}/.ssh/id_ed25519";
|
sops.sshKeyFile = "/home/${username}/.ssh/id_ed25519";
|
||||||
coding.all.enable = true;
|
coding.all.enable = true;
|
||||||
coding.editor.vscode.enable = lib.mkForce false;
|
coding.editor.vscode.enable = lib.mkForce false;
|
||||||
cli.misc.enable = true;
|
cli.misc.enable = true;
|
||||||
|
|||||||
@@ -1,43 +1,49 @@
|
|||||||
{
|
{
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
pkgs,
|
pkgs,
|
||||||
username,
|
username,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
localsend
|
localsend
|
||||||
|
|
||||||
rclone
|
|
||||||
|
|
||||||
wpsoffice-cn
|
wpsoffice-cn
|
||||||
wps-office-fonts
|
wps-office-fonts
|
||||||
ttf-wps-fonts
|
ttf-wps-fonts
|
||||||
evince
|
papers
|
||||||
|
|
||||||
anki
|
anki
|
||||||
|
|
||||||
ayugram-desktop
|
ayugram-desktop
|
||||||
telegram-desktop
|
|
||||||
signal-desktop
|
signal-desktop
|
||||||
discord
|
element-desktop
|
||||||
|
fractal
|
||||||
qq
|
qq
|
||||||
wechat
|
wechat
|
||||||
|
|
||||||
gnome-clocks
|
gnome-clocks
|
||||||
|
|
||||||
wineWowPackages.waylandFull
|
|
||||||
|
|
||||||
pavucontrol
|
|
||||||
pamixer
|
|
||||||
];
|
];
|
||||||
programs.zsh = {
|
programs.zsh = {
|
||||||
sessionVariables = {
|
sessionVariables = {
|
||||||
PATH = "/home/${username}/bin:$PATH";
|
PATH = "/home/${username}/bin:$PATH";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
programs.niri.settings = {
|
||||||
|
environment.STEAM_FORCE_DESKTOPUI_SCALING = "1.25";
|
||||||
|
outputs = {
|
||||||
|
eDP-1 = {
|
||||||
|
enable = true;
|
||||||
|
mode = {
|
||||||
|
width = 1920;
|
||||||
|
height = 1200;
|
||||||
|
refresh = 60.002;
|
||||||
|
};
|
||||||
|
scale = 1.25;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
my = {
|
my = {
|
||||||
@@ -45,8 +51,7 @@
|
|||||||
cli.all.enable = true;
|
cli.all.enable = true;
|
||||||
coding.all.enable = true;
|
coding.all.enable = true;
|
||||||
desktop.all.enable = true;
|
desktop.all.enable = true;
|
||||||
|
virt.moonlight.enable = true;
|
||||||
desktop.browser.librewolf.enable = lib.mkForce false;
|
|
||||||
|
|
||||||
i18n.fcitx5.enable = true;
|
i18n.fcitx5.enable = true;
|
||||||
|
|
||||||
@@ -59,9 +64,9 @@
|
|||||||
imageviewer = [ "org.gnome.Shotwell-Viewer.desktop" ];
|
imageviewer = [ "org.gnome.Shotwell-Viewer.desktop" ];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
"inode/directory" = [ "nemo.desktop" ];
|
"inode/directory" = [ "org.gnome.Nautilus.desktop" ];
|
||||||
|
|
||||||
"application/pdf" = [ "org.gnome.Evince.desktop" ];
|
"application/pdf" = [ "org.gnome.Papers.desktop" ];
|
||||||
|
|
||||||
"text/*" = editor;
|
"text/*" = editor;
|
||||||
"application/json" = editor;
|
"application/json" = editor;
|
||||||
@@ -92,15 +97,6 @@
|
|||||||
"image/png" = imageviewer;
|
"image/png" = imageviewer;
|
||||||
"image/webp" = imageviewer;
|
"image/webp" = imageviewer;
|
||||||
};
|
};
|
||||||
extraBookmarks =
|
|
||||||
let
|
|
||||||
homedir = config.my.home.home.homeDirectory;
|
|
||||||
in
|
|
||||||
[
|
|
||||||
"file://${homedir}/NAS NAS"
|
|
||||||
"file://${homedir}/NAS/imxyy_soope_ NAS imxyy_soope_"
|
|
||||||
"file://${homedir}/NAS/imxyy_soope_/OS NAS OS"
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
persist = {
|
persist = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -118,23 +114,26 @@
|
|||||||
".local/state"
|
".local/state"
|
||||||
".local/share/Anki2"
|
".local/share/Anki2"
|
||||||
".local/share/shotwell"
|
".local/share/shotwell"
|
||||||
".local/share/cheat.sh"
|
|
||||||
".local/share/Kingsoft"
|
".local/share/Kingsoft"
|
||||||
|
|
||||||
".local/share/AyuGramDesktop"
|
".local/share/AyuGramDesktop"
|
||||||
".local/share/TelegramDesktop"
|
".local/share/fractal"
|
||||||
".config/Signal"
|
".config/Signal"
|
||||||
".config/discord"
|
".config/Element"
|
||||||
".config/QQ"
|
".config/QQ"
|
||||||
".xwechat"
|
".xwechat"
|
||||||
|
|
||||||
".config/Kingsoft"
|
".config/Kingsoft"
|
||||||
".config/dconf"
|
".config/dconf"
|
||||||
".config/gh"
|
|
||||||
".config/pulse"
|
|
||||||
".config/pip"
|
".config/pip"
|
||||||
".config/libreoffice"
|
|
||||||
".config/sunshine"
|
".config/sunshine"
|
||||||
|
|
||||||
|
".gemini"
|
||||||
|
".claude"
|
||||||
|
".claude-code-router"
|
||||||
|
];
|
||||||
|
homeFiles = [
|
||||||
|
".claude.json"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
lib,
|
|
||||||
pkgs,
|
pkgs,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -10,10 +9,51 @@
|
|||||||
"biosdevname=0"
|
"biosdevname=0"
|
||||||
"net.ifnames=0"
|
"net.ifnames=0"
|
||||||
];
|
];
|
||||||
networking.networkmanager.enable = true;
|
networking = {
|
||||||
|
networkmanager.enable = true;
|
||||||
|
firewall.enable = false;
|
||||||
|
nftables = {
|
||||||
|
enable = true;
|
||||||
|
flushRuleset = true;
|
||||||
|
ruleset = ''
|
||||||
|
table inet firewall {
|
||||||
|
set LANv4 {
|
||||||
|
type ipv4_addr
|
||||||
|
flags interval
|
||||||
|
|
||||||
|
elements = { 10.0.0.0/8, 100.64.0.0/10, 172.16.0.0/12, 192.168.0.0/16, 169.254.0.0/16 }
|
||||||
|
}
|
||||||
|
set LANv6 {
|
||||||
|
type ipv6_addr
|
||||||
|
flags interval
|
||||||
|
|
||||||
|
elements = { fd00::/8, fe80::/10 }
|
||||||
|
}
|
||||||
|
|
||||||
|
chain output {
|
||||||
|
type filter hook output priority 100; policy accept;
|
||||||
|
}
|
||||||
|
|
||||||
|
chain input {
|
||||||
|
type filter hook input priority 0; policy drop;
|
||||||
|
iif lo accept
|
||||||
|
ct state invalid drop
|
||||||
|
ct state established,related accept
|
||||||
|
|
||||||
|
ip saddr @LANv4 accept
|
||||||
|
ip6 saddr @LANv6 accept
|
||||||
|
}
|
||||||
|
|
||||||
|
chain forward {
|
||||||
|
type filter hook forward priority 0; policy drop;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
sops.secrets.dae-imxyy-nix-x16 = {
|
sops.secrets.dae-imxyy-nix-x16 = {
|
||||||
sopsFile = sopsRoot + /dae-imxyy-nix-x16.dae;
|
sopsFile = secrets.dae-imxyy-nix-x16;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
services.dae = {
|
services.dae = {
|
||||||
@@ -22,7 +62,7 @@
|
|||||||
};
|
};
|
||||||
systemd.services.dae.after = [ "sops-nix.service" ];
|
systemd.services.dae.after = [ "sops-nix.service" ];
|
||||||
sops.secrets.mihomo = {
|
sops.secrets.mihomo = {
|
||||||
sopsFile = sopsRoot + /mihomo.yaml;
|
sopsFile = secrets.mihomo;
|
||||||
format = "yaml";
|
format = "yaml";
|
||||||
key = "";
|
key = "";
|
||||||
};
|
};
|
||||||
@@ -34,7 +74,7 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
sops.secrets.et-imxyy-nix-x16 = {
|
sops.secrets.et-imxyy-nix-x16 = {
|
||||||
sopsFile = sopsRoot + /et-imxyy-nix-x16.toml;
|
sopsFile = secrets.et-imxyy-nix-x16;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
@@ -44,10 +84,8 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix-x16.path}";
|
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix-x16.path}";
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Restart = lib.mkOverride 500 "always";
|
Restart = "always";
|
||||||
RestartMaxDelaySec = lib.mkOverride 500 "1m";
|
RestartSec = 30;
|
||||||
RestartSec = lib.mkOverride 500 "100ms";
|
|
||||||
RestartSteps = lib.mkOverride 500 9;
|
|
||||||
User = "root";
|
User = "root";
|
||||||
};
|
};
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
|||||||
@@ -1,9 +1,8 @@
|
|||||||
{
|
{
|
||||||
lib,
|
|
||||||
pkgs,
|
pkgs,
|
||||||
config,
|
config,
|
||||||
username,
|
username,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -36,36 +35,6 @@
|
|||||||
};
|
};
|
||||||
environment.variables.NIX_REMOTE = "daemon";
|
environment.variables.NIX_REMOTE = "daemon";
|
||||||
|
|
||||||
security.rtkit.enable = true;
|
|
||||||
services.pipewire = {
|
|
||||||
enable = true;
|
|
||||||
alsa.enable = false;
|
|
||||||
alsa.support32Bit = false;
|
|
||||||
pulse.enable = false;
|
|
||||||
audio.enable = false;
|
|
||||||
};
|
|
||||||
services.pulseaudio = {
|
|
||||||
enable = true;
|
|
||||||
support32Bit = true;
|
|
||||||
package = pkgs.pulseaudioFull;
|
|
||||||
extraConfig = ''
|
|
||||||
load-module module-switch-on-connect
|
|
||||||
unload-module module-suspend-on-idle
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
hardware.bluetooth = {
|
|
||||||
enable = true;
|
|
||||||
powerOnBoot = true;
|
|
||||||
settings = {
|
|
||||||
General = {
|
|
||||||
Enable = "Source,Sink,Media,Socket";
|
|
||||||
Disable = "HeadSet";
|
|
||||||
MultiProfile = "multiple";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
users.extraUsers.${username}.extraGroups = [ "audio" ];
|
|
||||||
|
|
||||||
fonts = {
|
fonts = {
|
||||||
enableDefaultPackages = false;
|
enableDefaultPackages = false;
|
||||||
fontDir.enable = true;
|
fontDir.enable = true;
|
||||||
@@ -102,6 +71,9 @@
|
|||||||
|
|
||||||
services.printing.enable = true;
|
services.printing.enable = true;
|
||||||
|
|
||||||
|
services.upower.enable = true;
|
||||||
|
services.power-profiles-daemon.enable = true;
|
||||||
|
|
||||||
services.keyd = {
|
services.keyd = {
|
||||||
enable = true;
|
enable = true;
|
||||||
keyboards.default.settings = {
|
keyboards.default.settings = {
|
||||||
@@ -134,7 +106,7 @@
|
|||||||
];
|
];
|
||||||
|
|
||||||
sops.secrets.imxyy-nix-rclone = {
|
sops.secrets.imxyy-nix-rclone = {
|
||||||
sopsFile = sopsRoot + /imxyy-nix-rclone.conf;
|
sopsFile = secrets.imxyy-nix-rclone;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
fileSystems = {
|
fileSystems = {
|
||||||
@@ -154,21 +126,6 @@
|
|||||||
"vfs-cache-mode=full"
|
"vfs-cache-mode=full"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
"/home/${username}/NAS" = {
|
|
||||||
device = "//10.0.0.1/share";
|
|
||||||
fsType = "cifs";
|
|
||||||
options = [
|
|
||||||
"username=nas"
|
|
||||||
"password=nasshare"
|
|
||||||
"x-systemd.automount,noauto,x-systemd.idle-timeout=60,x-systemd.device-timeout=5s,x-systemd.mount-timeout=5s"
|
|
||||||
"nodev"
|
|
||||||
"nofail"
|
|
||||||
"uid=1000"
|
|
||||||
"gid=100"
|
|
||||||
"vers=3"
|
|
||||||
"rw"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
my.persist.nixosDirs = [ "/etc/NetworkManager/system-connections" ];
|
my.persist.nixosDirs = [ "/etc/NetworkManager/system-connections" ];
|
||||||
|
|||||||
@@ -1,37 +1,28 @@
|
|||||||
{
|
{
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
pkgs,
|
pkgs,
|
||||||
username,
|
username,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
localsend
|
localsend
|
||||||
|
|
||||||
rclone
|
|
||||||
|
|
||||||
wpsoffice-cn
|
wpsoffice-cn
|
||||||
wps-office-fonts
|
wps-office-fonts
|
||||||
ttf-wps-fonts
|
ttf-wps-fonts
|
||||||
evince
|
papers
|
||||||
|
|
||||||
anki
|
anki
|
||||||
|
|
||||||
ayugram-desktop
|
ayugram-desktop
|
||||||
telegram-desktop
|
|
||||||
signal-desktop
|
signal-desktop
|
||||||
discord
|
element-desktop
|
||||||
|
fractal
|
||||||
qq
|
qq
|
||||||
wechat
|
wechat
|
||||||
|
|
||||||
gnome-clocks
|
gnome-clocks
|
||||||
|
|
||||||
wineWowPackages.waylandFull
|
|
||||||
|
|
||||||
pavucontrol
|
|
||||||
pamixer
|
|
||||||
];
|
];
|
||||||
programs.zsh = {
|
programs.zsh = {
|
||||||
shellAliases = {
|
shellAliases = {
|
||||||
@@ -91,8 +82,6 @@
|
|||||||
coding.all.enable = true;
|
coding.all.enable = true;
|
||||||
desktop.all.enable = true;
|
desktop.all.enable = true;
|
||||||
|
|
||||||
desktop.browser.librewolf.enable = lib.mkForce false;
|
|
||||||
|
|
||||||
i18n.fcitx5.enable = true;
|
i18n.fcitx5.enable = true;
|
||||||
|
|
||||||
xdg = {
|
xdg = {
|
||||||
@@ -104,9 +93,9 @@
|
|||||||
imageviewer = [ "org.gnome.Shotwell-Viewer.desktop" ];
|
imageviewer = [ "org.gnome.Shotwell-Viewer.desktop" ];
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
"inode/directory" = [ "nemo.desktop" ];
|
"inode/directory" = [ "org.gnome.Nautilus.desktop" ];
|
||||||
|
|
||||||
"application/pdf" = [ "org.gnome.Evince.desktop" ];
|
"application/pdf" = [ "org.gnome.Papers.desktop" ];
|
||||||
|
|
||||||
"text/*" = editor;
|
"text/*" = editor;
|
||||||
"application/json" = editor;
|
"application/json" = editor;
|
||||||
@@ -137,16 +126,6 @@
|
|||||||
"image/png" = imageviewer;
|
"image/png" = imageviewer;
|
||||||
"image/webp" = imageviewer;
|
"image/webp" = imageviewer;
|
||||||
};
|
};
|
||||||
extraBookmarks =
|
|
||||||
let
|
|
||||||
homedir = config.my.home.home.homeDirectory;
|
|
||||||
in
|
|
||||||
[
|
|
||||||
"file://${homedir}/Documents/%E7%8F%AD%E7%BA%A7%E4%BA%8B%E5%8A%A1 班级事务"
|
|
||||||
"file://${homedir}/NAS NAS"
|
|
||||||
"file://${homedir}/NAS/imxyy_soope_ NAS imxyy_soope_"
|
|
||||||
"file://${homedir}/NAS/imxyy_soope_/OS NAS OS"
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
persist = {
|
persist = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@@ -162,23 +141,23 @@
|
|||||||
".local/state"
|
".local/state"
|
||||||
".local/share/Anki2"
|
".local/share/Anki2"
|
||||||
".local/share/shotwell"
|
".local/share/shotwell"
|
||||||
".local/share/cheat.sh"
|
|
||||||
".local/share/Kingsoft"
|
".local/share/Kingsoft"
|
||||||
|
|
||||||
".local/share/AyuGramDesktop"
|
".local/share/AyuGramDesktop"
|
||||||
".local/share/TelegramDesktop"
|
".local/share/fractal"
|
||||||
".config/Signal"
|
".config/Signal"
|
||||||
".config/discord"
|
".config/Element"
|
||||||
".config/QQ"
|
".config/QQ"
|
||||||
".xwechat"
|
".xwechat"
|
||||||
|
|
||||||
".config/Kingsoft"
|
".config/Kingsoft"
|
||||||
".config/dconf"
|
".config/dconf"
|
||||||
".config/gh"
|
|
||||||
".config/pulse"
|
|
||||||
".config/pip"
|
".config/pip"
|
||||||
".config/libreoffice"
|
|
||||||
".config/sunshine"
|
".config/sunshine"
|
||||||
|
|
||||||
|
".gemini"
|
||||||
|
".claude"
|
||||||
|
".claude-code-router"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -2,8 +2,7 @@
|
|||||||
config,
|
config,
|
||||||
lib,
|
lib,
|
||||||
pkgs,
|
pkgs,
|
||||||
sopsRoot,
|
secrets,
|
||||||
username,
|
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
@@ -70,6 +69,7 @@
|
|||||||
chain input {
|
chain input {
|
||||||
type filter hook input priority 0; policy drop;
|
type filter hook input priority 0; policy drop;
|
||||||
iif lo accept
|
iif lo accept
|
||||||
|
iifname waydroid0 accept
|
||||||
ct state invalid drop
|
ct state invalid drop
|
||||||
ct state established,related accept
|
ct state established,related accept
|
||||||
|
|
||||||
@@ -79,6 +79,9 @@
|
|||||||
|
|
||||||
chain forward {
|
chain forward {
|
||||||
type filter hook forward priority 0; policy drop;
|
type filter hook forward priority 0; policy drop;
|
||||||
|
|
||||||
|
iifname waydroid0 accept
|
||||||
|
oifname waydroid0 accept
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
@@ -86,7 +89,7 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
sops.secrets.dae-imxyy-nix = {
|
sops.secrets.dae-imxyy-nix = {
|
||||||
sopsFile = sopsRoot + /dae-imxyy-nix.dae;
|
sopsFile = secrets.dae-imxyy-nix;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
services.dae = {
|
services.dae = {
|
||||||
@@ -95,7 +98,7 @@
|
|||||||
};
|
};
|
||||||
systemd.services.dae.after = [ "sops-nix.service" ];
|
systemd.services.dae.after = [ "sops-nix.service" ];
|
||||||
sops.secrets.mihomo = {
|
sops.secrets.mihomo = {
|
||||||
sopsFile = sopsRoot + /mihomo.yaml;
|
sopsFile = secrets.mihomo;
|
||||||
format = "yaml";
|
format = "yaml";
|
||||||
key = "";
|
key = "";
|
||||||
};
|
};
|
||||||
@@ -107,7 +110,7 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
sops.secrets.et-imxyy-nix = {
|
sops.secrets.et-imxyy-nix = {
|
||||||
sopsFile = sopsRoot + /et-imxyy-nix.toml;
|
sopsFile = secrets.et-imxyy-nix;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
environment.systemPackages = [ pkgs.easytier ];
|
environment.systemPackages = [ pkgs.easytier ];
|
||||||
@@ -115,10 +118,8 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix.path}";
|
script = "${pkgs.easytier}/bin/easytier-core -c ${config.sops.secrets.et-imxyy-nix.path}";
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Restart = lib.mkOverride 500 "always";
|
Restart = "always";
|
||||||
RestartMaxDelaySec = lib.mkOverride 500 "1m";
|
RestartSec = 30;
|
||||||
RestartSec = lib.mkOverride 500 "100ms";
|
|
||||||
RestartSteps = lib.mkOverride 500 9;
|
|
||||||
User = "root";
|
User = "root";
|
||||||
};
|
};
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
pkgs,
|
pkgs,
|
||||||
config,
|
config,
|
||||||
username,
|
username,
|
||||||
sopsRoot,
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
@@ -22,7 +22,7 @@ let
|
|||||||
temp = line.split(" ")
|
temp = line.split(" ")
|
||||||
bus = temp[1]
|
bus = temp[1]
|
||||||
device = temp[3][:-1]
|
device = temp[3][:-1]
|
||||||
subprocess.run(["${lib.getExe usbreset}", f"/dev/bus/usb/{bus}/{device}"])
|
subprocess.run(["${lib.getExe' pkgs.usbutils "usbreset"}", f"{bus}/{device}"])
|
||||||
return True
|
return True
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
@@ -36,44 +36,6 @@ let
|
|||||||
with open("/tmp/.btreseted", "w"):
|
with open("/tmp/.btreseted", "w"):
|
||||||
...
|
...
|
||||||
'';
|
'';
|
||||||
usbreset = pkgs.writeCBin "usbreset" ''
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <sys/ioctl.h>
|
|
||||||
|
|
||||||
#include <linux/usbdevice_fs.h>
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
const char *filename;
|
|
||||||
int fd;
|
|
||||||
int rc;
|
|
||||||
|
|
||||||
if (argc != 2) {
|
|
||||||
fprintf(stderr, "Usage: usbreset device-filename\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
filename = argv[1];
|
|
||||||
|
|
||||||
fd = open(filename, O_WRONLY);
|
|
||||||
if (fd < 0) {
|
|
||||||
perror("Error opening output file");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("Resetting USB device %s\n", filename);
|
|
||||||
rc = ioctl(fd, USBDEVFS_RESET, 0);
|
|
||||||
if (rc < 0) {
|
|
||||||
perror("Error in ioctl");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
printf("Reset successful\n");
|
|
||||||
|
|
||||||
close(fd);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
'';
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
security.pam.loginLimits = [
|
security.pam.loginLimits = [
|
||||||
@@ -111,36 +73,6 @@ in
|
|||||||
};
|
};
|
||||||
environment.variables.NIX_REMOTE = "daemon";
|
environment.variables.NIX_REMOTE = "daemon";
|
||||||
|
|
||||||
security.rtkit.enable = true;
|
|
||||||
services.pipewire = {
|
|
||||||
enable = true;
|
|
||||||
alsa.enable = false;
|
|
||||||
alsa.support32Bit = false;
|
|
||||||
pulse.enable = false;
|
|
||||||
audio.enable = false;
|
|
||||||
};
|
|
||||||
services.pulseaudio = {
|
|
||||||
enable = true;
|
|
||||||
support32Bit = true;
|
|
||||||
package = pkgs.pulseaudioFull;
|
|
||||||
extraConfig = ''
|
|
||||||
load-module module-switch-on-connect
|
|
||||||
unload-module module-suspend-on-idle
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
hardware.bluetooth = {
|
|
||||||
enable = true;
|
|
||||||
powerOnBoot = true;
|
|
||||||
settings = {
|
|
||||||
General = {
|
|
||||||
Enable = "Source,Sink,Media,Socket";
|
|
||||||
Disable = "HeadSet";
|
|
||||||
MultiProfile = "multiple";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
users.extraUsers.${username}.extraGroups = [ "audio" ];
|
|
||||||
|
|
||||||
fonts = {
|
fonts = {
|
||||||
enableDefaultPackages = false;
|
enableDefaultPackages = false;
|
||||||
fontDir.enable = true;
|
fontDir.enable = true;
|
||||||
@@ -179,16 +111,22 @@ in
|
|||||||
|
|
||||||
services.keyd = {
|
services.keyd = {
|
||||||
enable = true;
|
enable = true;
|
||||||
keyboards.default.settings = {
|
keyboards = {
|
||||||
main = {
|
default.settings = {
|
||||||
capslock = "overload(control, esc)";
|
main = {
|
||||||
home = "end";
|
capslock = "overload(control, esc)";
|
||||||
|
home = "end";
|
||||||
|
};
|
||||||
|
shift = {
|
||||||
|
home = "home";
|
||||||
|
};
|
||||||
|
control = {
|
||||||
|
delete = "print";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
shift = {
|
kone-pro-owl-eye = {
|
||||||
home = "home";
|
ids = [ "1e7d:2dcd" ];
|
||||||
};
|
settings.main.mouse2 = "rightmouse";
|
||||||
control = {
|
|
||||||
delete = "print";
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@@ -199,6 +137,9 @@ in
|
|||||||
programs.wireshark.package = pkgs.wireshark;
|
programs.wireshark.package = pkgs.wireshark;
|
||||||
users.users.${username}.extraGroups = [ "wireshark" ];
|
users.users.${username}.extraGroups = [ "wireshark" ];
|
||||||
|
|
||||||
|
virtualisation.waydroid.enable = true;
|
||||||
|
my.persist.homeDirs = [ ".local/share/waydroid" ];
|
||||||
|
|
||||||
services.sunshine = {
|
services.sunshine = {
|
||||||
enable = true;
|
enable = true;
|
||||||
autoStart = true;
|
autoStart = true;
|
||||||
@@ -225,7 +166,7 @@ in
|
|||||||
];
|
];
|
||||||
|
|
||||||
sops.secrets.imxyy-nix-rclone = {
|
sops.secrets.imxyy-nix-rclone = {
|
||||||
sopsFile = sopsRoot + /imxyy-nix-rclone.conf;
|
sopsFile = secrets.imxyy-nix-rclone;
|
||||||
format = "binary";
|
format = "binary";
|
||||||
};
|
};
|
||||||
fileSystems = {
|
fileSystems = {
|
||||||
|
|||||||
320
flake.lock
generated
320
flake.lock
generated
@@ -5,11 +5,11 @@
|
|||||||
"fromYaml": "fromYaml"
|
"fromYaml": "fromYaml"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1746562888,
|
"lastModified": 1755819240,
|
||||||
"narHash": "sha256-YgNJQyB5dQiwavdDFBMNKk1wyS77AtdgDk/VtU6wEaI=",
|
"narHash": "sha256-qcMhnL7aGAuFuutH4rq9fvAhCpJWVHLcHVZLtPctPlo=",
|
||||||
"owner": "SenchoPens",
|
"owner": "SenchoPens",
|
||||||
"repo": "base16.nix",
|
"repo": "base16.nix",
|
||||||
"rev": "806a1777a5db2a1ef9d5d6f493ef2381047f2b89",
|
"rev": "75ed5e5e3fce37df22e49125181fa37899c3ccd6",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -37,11 +37,11 @@
|
|||||||
"base16-helix": {
|
"base16-helix": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1748408240,
|
"lastModified": 1752979451,
|
||||||
"narHash": "sha256-9M2b1rMyMzJK0eusea0x3lyh3mu5nMeEDSc4RZkGm+g=",
|
"narHash": "sha256-0CQM+FkYy0fOO/sMGhOoNL80ftsAzYCg9VhIrodqusM=",
|
||||||
"owner": "tinted-theming",
|
"owner": "tinted-theming",
|
||||||
"repo": "base16-helix",
|
"repo": "base16-helix",
|
||||||
"rev": "6c711ab1a9db6f51e2f6887cc3345530b33e152e",
|
"rev": "27cf1e66e50abc622fb76a3019012dc07c678fac",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -98,6 +98,26 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"catppuccin": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1759273174,
|
||||||
|
"narHash": "sha256-aHN6dAD72IsNvNlzU3nbV4DJRb1qPvURgWIzHeYsBbc=",
|
||||||
|
"owner": "catppuccin",
|
||||||
|
"repo": "nix",
|
||||||
|
"rev": "5f7dc8bab8af6ba612ef8dc7cd44e38ba6cfd51a",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "catppuccin",
|
||||||
|
"repo": "nix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"chaotic": {
|
"chaotic": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-schemas": "flake-schemas",
|
"flake-schemas": "flake-schemas",
|
||||||
@@ -107,11 +127,11 @@
|
|||||||
"rust-overlay": "rust-overlay"
|
"rust-overlay": "rust-overlay"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752141190,
|
"lastModified": 1759235653,
|
||||||
"narHash": "sha256-RHNq77Z84BtLTwyRtrBffm5V9006Dqw4vh3vrvULlxM=",
|
"narHash": "sha256-sKFehUxXCzM6E1LcmnRa/O6HKsRI/TGtciG5ulAJt08=",
|
||||||
"owner": "chaotic-cx",
|
"owner": "chaotic-cx",
|
||||||
"repo": "nyx",
|
"repo": "nyx",
|
||||||
"rev": "ef0794b8e94eea166407141f7e92da75f6df925a",
|
"rev": "2bf7f138e42fa8b2133761edab64263505cb83bf",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -128,11 +148,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1750940343,
|
"lastModified": 1757962227,
|
||||||
"narHash": "sha256-qmc/jreM09MOwQ8dOa/+yyh99rU7TowSqo8L33VHfto=",
|
"narHash": "sha256-BENROvRjnKLjCc1qwGgScfk6WIdHGwz4vZhsmfa///Q=",
|
||||||
"owner": "Bali10050",
|
"owner": "Bali10050",
|
||||||
"repo": "Darkly",
|
"repo": "Darkly",
|
||||||
"rev": "77770c8d3c35f7ad39da2c57122c360096df0aac",
|
"rev": "c1446a049c4e2f78afbd90d8b642dc73a3027f1a",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -171,11 +191,11 @@
|
|||||||
"rust-analyzer-src": "rust-analyzer-src"
|
"rust-analyzer-src": "rust-analyzer-src"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752129689,
|
"lastModified": 1759251341,
|
||||||
"narHash": "sha256-0Xq5tZbvgZvxbbxv6kRHFuZE4Tq2za016NXh32nX0+Q=",
|
"narHash": "sha256-0vt4IQnTLyAhaeom3h9GOCpO2+av+wK4zP7O8BSKr6I=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "fenix",
|
"repo": "fenix",
|
||||||
"rev": "70bb04a7de606a75ba0a2ee9d47b99802780b35d",
|
"rev": "af8a7505a1c62fab493157ea380a05c094bb63af",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -187,11 +207,11 @@
|
|||||||
"firefox-gnome-theme": {
|
"firefox-gnome-theme": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1748383148,
|
"lastModified": 1758112371,
|
||||||
"narHash": "sha256-pGvD/RGuuPf/4oogsfeRaeMm6ipUIznI2QSILKjKzeA=",
|
"narHash": "sha256-lizRM2pj6PHrR25yimjyFn04OS4wcdbc38DCdBVa2rk=",
|
||||||
"owner": "rafaelmardojai",
|
"owner": "rafaelmardojai",
|
||||||
"repo": "firefox-gnome-theme",
|
"repo": "firefox-gnome-theme",
|
||||||
"rev": "4eb2714fbed2b80e234312611a947d6cb7d70caf",
|
"rev": "0909cfe4a2af8d358ad13b20246a350e14c2473d",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -273,27 +293,6 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"flake-parts_3": {
|
"flake-parts_3": {
|
||||||
"inputs": {
|
|
||||||
"nixpkgs-lib": [
|
|
||||||
"nur",
|
|
||||||
"nixpkgs"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1733312601,
|
|
||||||
"narHash": "sha256-4pDvzqnegAfRkPwO3wmwBhVi/Sye1mzps0zHWYnP88c=",
|
|
||||||
"owner": "hercules-ci",
|
|
||||||
"repo": "flake-parts",
|
|
||||||
"rev": "205b12d8b7cd4802fbcb8e8ef6a0f1408781a4f9",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "hercules-ci",
|
|
||||||
"repo": "flake-parts",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"flake-parts_4": {
|
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs-lib": [
|
"nixpkgs-lib": [
|
||||||
"stylix",
|
"stylix",
|
||||||
@@ -301,11 +300,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751413152,
|
"lastModified": 1756770412,
|
||||||
"narHash": "sha256-Tyw1RjYEsp5scoigs1384gIg6e0GoBVjms4aXFfRssQ=",
|
"narHash": "sha256-+uWLQZccFHwqpGqr2Yt5VsW/PbeJVTn9Dk6SHWhNRPw=",
|
||||||
"owner": "hercules-ci",
|
"owner": "hercules-ci",
|
||||||
"repo": "flake-parts",
|
"repo": "flake-parts",
|
||||||
"rev": "77826244401ea9de6e3bac47c2db46005e1f30b5",
|
"rev": "4524271976b625a4a605beefd893f270620fd751",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -457,11 +456,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1748528448,
|
"lastModified": 1755219990,
|
||||||
"narHash": "sha256-Tyn+PgBm78Ibq28/WbEz8+pYJZMdbJKsyXMCpT6TjrM=",
|
"narHash": "sha256-/znXwik9nC9TY6dwq0SR60MAi9IEZi2InRSRjfhKu1s=",
|
||||||
"owner": "imxyy1soope1",
|
"owner": "imxyy1soope1",
|
||||||
"repo": "go-musicfox",
|
"repo": "go-musicfox",
|
||||||
"rev": "1870fd3501631577ad4daef1489b03885abcb037",
|
"rev": "938c4d6bb2a318bc6251f3b11fa8cf54d29b4419",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -500,11 +499,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751824240,
|
"lastModified": 1759172751,
|
||||||
"narHash": "sha256-aDDC0CHTlL7QDKWWhdbEgVPK6KwWt+ca0QkmHYZxMzI=",
|
"narHash": "sha256-E8W8sRXfrvkFW26GuuiWq6QfReU7m5+cngwHuRo/3jc=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "fd9e55f5fac45a26f6169310afca64d56b681935",
|
"rev": "12fa8548feefa9a10266ba65152fd1a787cdde8f",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -520,11 +519,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752202894,
|
"lastModified": 1759261733,
|
||||||
"narHash": "sha256-knafgng4gCjZIUMyAEWjxxdols6n/swkYnbWr+oF+1w=",
|
"narHash": "sha256-G104PUPKBgJmcu4NWs0LUaPpSOTD4jiq4mamLWu3Oc0=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "fab659b346c0d4252208434c3c4b3983a4b38fec",
|
"rev": "5a21f4819ee1be645f46d6b255d49f4271ef6723",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -542,11 +541,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1743604125,
|
"lastModified": 1752603129,
|
||||||
"narHash": "sha256-ZD61DNbsBt1mQbinAaaEqKaJk2RFo9R/j+eYWeGMx7A=",
|
"narHash": "sha256-S+wmHhwNQ5Ru689L2Gu8n1OD6s9eU9n9mD827JNR+kw=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "180fd43eea296e62ae68e079fcf56aba268b9a1a",
|
"rev": "e8c19a3cec2814c754f031ab3ae7316b64da085b",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -595,11 +594,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751529406,
|
"lastModified": 1757230583,
|
||||||
"narHash": "sha256-jwKDHyUycp678zDYa5Hyfq3msO73YMXdZPxp96dU7po=",
|
"narHash": "sha256-4uqu7sFPOaVTCogsxaGMgbzZ2vK40GVGMfUmrvK3/LY=",
|
||||||
"owner": "Jovian-Experiments",
|
"owner": "Jovian-Experiments",
|
||||||
"repo": "Jovian-NixOS",
|
"repo": "Jovian-NixOS",
|
||||||
"rev": "b2e5ce654e4f5bf8905c2e07a96dcf4966e6277d",
|
"rev": "fc3960e6c32c9d4f95fff2ef84444284d24d3bea",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -658,21 +657,17 @@
|
|||||||
"inputs": {
|
"inputs": {
|
||||||
"niri-stable": "niri-stable",
|
"niri-stable": "niri-stable",
|
||||||
"niri-unstable": "niri-unstable",
|
"niri-unstable": "niri-unstable",
|
||||||
"nixpkgs": [
|
"nixpkgs": "nixpkgs_5",
|
||||||
"nixpkgs"
|
"nixpkgs-stable": "nixpkgs-stable",
|
||||||
],
|
|
||||||
"nixpkgs-stable": [
|
|
||||||
"nixpkgs-stable"
|
|
||||||
],
|
|
||||||
"xwayland-satellite-stable": "xwayland-satellite-stable",
|
"xwayland-satellite-stable": "xwayland-satellite-stable",
|
||||||
"xwayland-satellite-unstable": "xwayland-satellite-unstable"
|
"xwayland-satellite-unstable": "xwayland-satellite-unstable"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752078530,
|
"lastModified": 1759207481,
|
||||||
"narHash": "sha256-TrRmlYdhWcadWvBpDjB9Xlry4uT4ZUIO46d+o5tjtCQ=",
|
"narHash": "sha256-xhUr1oMQwL/8h8xnPi5QxUHRFDHoCofhw8Jy7qTD4BY=",
|
||||||
"owner": "sodiboo",
|
"owner": "sodiboo",
|
||||||
"repo": "niri-flake",
|
"repo": "niri-flake",
|
||||||
"rev": "d231d92313192d4d0c78d6ef04167fed9dee87cf",
|
"rev": "d425163158a96a26924597574316a627d2e982aa",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -684,16 +679,16 @@
|
|||||||
"niri-stable": {
|
"niri-stable": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1748151941,
|
"lastModified": 1756556321,
|
||||||
"narHash": "sha256-z4viQZLgC2bIJ3VrzQnR+q2F3gAOEQpU1H5xHtX/2fs=",
|
"narHash": "sha256-RLD89dfjN0RVO86C/Mot0T7aduCygPGaYbog566F0Qo=",
|
||||||
"owner": "YaLTeR",
|
"owner": "YaLTeR",
|
||||||
"repo": "niri",
|
"repo": "niri",
|
||||||
"rev": "8ba57fcf25d2fc9565131684a839d58703f1dae7",
|
"rev": "01be0e65f4eb91a9cd624ac0b76aaeab765c7294",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "YaLTeR",
|
"owner": "YaLTeR",
|
||||||
"ref": "v25.05.1",
|
"ref": "v25.08",
|
||||||
"repo": "niri",
|
"repo": "niri",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -701,11 +696,11 @@
|
|||||||
"niri-unstable": {
|
"niri-unstable": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1750791124,
|
"lastModified": 1758691861,
|
||||||
"narHash": "sha256-F5iVU/hjoSHSSe0gllxm0PcAaseEtGNanYK5Ha3k2Tg=",
|
"narHash": "sha256-CYgoGrY/Fx+hjzp8graTxJw1M7mn1f2jBkK26M04T0s=",
|
||||||
"owner": "YaLTeR",
|
"owner": "YaLTeR",
|
||||||
"repo": "niri",
|
"repo": "niri",
|
||||||
"rev": "37458d94b288945f6cfbd3c5c233f634d59f246c",
|
"rev": "e837e39623457dc5ad29c34a5ce4d4616e5fbf1e",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -804,11 +799,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752199438,
|
"lastModified": 1758785683,
|
||||||
"narHash": "sha256-xSBMmGtq8K4Qv80TMqREmESCAsRLJRHAbFH2T/2Bf1Y=",
|
"narHash": "sha256-mRn51IeEBXeNh5a6xNLylk4PKBX0s/QQxgkEbYoPq/w=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "NixOS-WSL",
|
"repo": "NixOS-WSL",
|
||||||
"rev": "d34d9412556d3a896e294534ccd25f53b6822e80",
|
"rev": "1bfb978f2f6261b6086e04af17f9418e1fe36d70",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -819,11 +814,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751984180,
|
"lastModified": 1759147044,
|
||||||
"narHash": "sha256-LwWRsENAZJKUdD3SpLluwDmdXY9F45ZEgCb0X+xgOL0=",
|
"narHash": "sha256-3ZPFytJOcLjTChljeaGgoaNj+tOqzgEpqZAvRe3bU90=",
|
||||||
"owner": "NixOS",
|
"owner": "PedroHLC",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "9807714d6944a957c2e036f84b0ff8caf9930bc0",
|
"rev": "18e83bbe13aa50992777832b52bd0e0d8585fb3b",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -847,11 +842,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs-master": {
|
"nixpkgs-master": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752206449,
|
"lastModified": 1759299389,
|
||||||
"narHash": "sha256-NVAbC/s4CupABWGXF8M9mDiVw/n0YCftxwc1KatVjDk=",
|
"narHash": "sha256-2W+bpX2yD4uAV9XfjaUO4uRv63e+0CIPnafub3VPw6o=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "1bd4d0d4a678d48b63eb18f457d74df2fcee6c69",
|
"rev": "53389b4777be03b7d223abef9bb0d8ee030ee1a5",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -863,11 +858,27 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs-stable": {
|
"nixpkgs-stable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752203688,
|
"lastModified": 1759143472,
|
||||||
"narHash": "sha256-uJ054F5PVGPu5SvLPMevhdY/EfK0X5DUyRtXhQYNUyo=",
|
"narHash": "sha256-TvODmeR2W7yX/JmOCmP+lAFNkTT7hAxYcF3Kz8SZV3w=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "5ed4e25ab58fd4c028b59d5611e14ea64de51d23",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixos-25.05",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"nixpkgs-stable_2": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1759281824,
|
||||||
|
"narHash": "sha256-FIBE1qXv9TKvSNwst6FumyHwCRH3BlWDpfsnqRDCll0=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "a70a12c75e13aa546c20ce0fe515de634d52c39e",
|
"rev": "5b5be50345d4113d04ba58c444348849f5585b4a",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -879,16 +890,16 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs-unstable": {
|
"nixpkgs-unstable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752124863,
|
"lastModified": 1759036355,
|
||||||
"narHash": "sha256-5rWuf6RAlMDp/CAEuyYEz7ryxzgjxOCgUDhWEef864c=",
|
"narHash": "sha256-0m27AKv6ka+q270dw48KflE0LwQYrO7Fm4/2//KCVWg=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "40de82b434526744da778ed53c742c1282d9e75e",
|
"rev": "e9f00bd893984bc8ce46c895c3bf7cac95331127",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"ref": "nixos-unstable-small",
|
"ref": "nixos-unstable",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -943,40 +954,21 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs_5": {
|
"nixpkgs_5": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751984180,
|
"lastModified": 1759036355,
|
||||||
"narHash": "sha256-LwWRsENAZJKUdD3SpLluwDmdXY9F45ZEgCb0X+xgOL0=",
|
"narHash": "sha256-0m27AKv6ka+q270dw48KflE0LwQYrO7Fm4/2//KCVWg=",
|
||||||
"owner": "nixos",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "9807714d6944a957c2e036f84b0ff8caf9930bc0",
|
"rev": "e9f00bd893984bc8ce46c895c3bf7cac95331127",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "nixos",
|
"owner": "NixOS",
|
||||||
"ref": "nixos-unstable",
|
"ref": "nixos-unstable",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nur": {
|
"nur": {
|
||||||
"inputs": {
|
|
||||||
"flake-parts": "flake-parts_3",
|
|
||||||
"nixpkgs": "nixpkgs_5"
|
|
||||||
},
|
|
||||||
"locked": {
|
|
||||||
"lastModified": 1752207112,
|
|
||||||
"narHash": "sha256-dnVoQSGQqEGJQzS6iHAG95c0oFrezzBinwu1bDLj9J4=",
|
|
||||||
"owner": "nix-community",
|
|
||||||
"repo": "NUR",
|
|
||||||
"rev": "f166dc14862dfec043f9545e8291cc4402f8b866",
|
|
||||||
"type": "github"
|
|
||||||
},
|
|
||||||
"original": {
|
|
||||||
"owner": "nix-community",
|
|
||||||
"repo": "NUR",
|
|
||||||
"type": "github"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"nur_2": {
|
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-parts": [
|
"flake-parts": [
|
||||||
"stylix",
|
"stylix",
|
||||||
@@ -988,11 +980,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751906969,
|
"lastModified": 1758998580,
|
||||||
"narHash": "sha256-BSQAOdPnzdpOuCdAGSJmefSDlqmStFNScEnrWzSqKPw=",
|
"narHash": "sha256-VLx0z396gDCGSiowLMFz5XRO/XuNV+4EnDYjdJhHvUk=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "NUR",
|
"repo": "NUR",
|
||||||
"rev": "ddb679f4131e819efe3bbc6457ba19d7ad116f25",
|
"rev": "ba8d9c98f5f4630bcb0e815ab456afd90c930728",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1001,28 +993,26 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"quickshell": {
|
"plant": {
|
||||||
"inputs": {
|
"flake": false,
|
||||||
"nixpkgs": [
|
|
||||||
"nixpkgs"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752146885,
|
"lastModified": 1758423341,
|
||||||
"narHash": "sha256-ZJK989GL+bTCQSxbG8v8/7tHMCEl/FPovkeDBNyClQE=",
|
"narHash": "sha256-dHcKh7T8I70bKPwgqO5MxZ9bWHINwzRPhFp5waQy2r8=",
|
||||||
"ref": "refs/heads/master",
|
"ref": "refs/heads/master",
|
||||||
"rev": "d7079b75241c6e2b67f2429996fa7679ffc052e2",
|
"rev": "08dc0b3889797eb3618c7475c3c367ec0e5fdf40",
|
||||||
"revCount": 616,
|
"revCount": 6,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.outfoxxed.me/outfoxxed/quickshell"
|
"url": "ssh://git@git.imxyy.top:2222/imxyy1soope1/HF-plant.git"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
"rev": "08dc0b3889797eb3618c7475c3c367ec0e5fdf40",
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.outfoxxed.me/outfoxxed/quickshell"
|
"url": "ssh://git@git.imxyy.top:2222/imxyy1soope1/HF-plant.git"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"root": {
|
"root": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
|
"catppuccin": "catppuccin",
|
||||||
"chaotic": "chaotic",
|
"chaotic": "chaotic",
|
||||||
"darkly": "darkly",
|
"darkly": "darkly",
|
||||||
"fenix": "fenix",
|
"fenix": "fenix",
|
||||||
@@ -1037,10 +1027,9 @@
|
|||||||
"nixpkgs-unstable"
|
"nixpkgs-unstable"
|
||||||
],
|
],
|
||||||
"nixpkgs-master": "nixpkgs-master",
|
"nixpkgs-master": "nixpkgs-master",
|
||||||
"nixpkgs-stable": "nixpkgs-stable",
|
"nixpkgs-stable": "nixpkgs-stable_2",
|
||||||
"nixpkgs-unstable": "nixpkgs-unstable",
|
"nixpkgs-unstable": "nixpkgs-unstable",
|
||||||
"nur": "nur",
|
"plant": "plant",
|
||||||
"quickshell": "quickshell",
|
|
||||||
"sops-nix": "sops-nix",
|
"sops-nix": "sops-nix",
|
||||||
"stylix": "stylix",
|
"stylix": "stylix",
|
||||||
"zen": "zen"
|
"zen": "zen"
|
||||||
@@ -1049,11 +1038,11 @@
|
|||||||
"rust-analyzer-src": {
|
"rust-analyzer-src": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752086493,
|
"lastModified": 1759134797,
|
||||||
"narHash": "sha256-USpVUdiWXDfPoh+agbvoBQaBhg3ZdKZgHXo/HikMfVo=",
|
"narHash": "sha256-YPi+jL3tx/yC5J5l7/OB7Lnlr9BMTzYnZtm7tRJzUNg=",
|
||||||
"owner": "rust-lang",
|
"owner": "rust-lang",
|
||||||
"repo": "rust-analyzer",
|
"repo": "rust-analyzer",
|
||||||
"rev": "6e3abe164b9036048dce1a3aa65a7e7e5200c0d3",
|
"rev": "062ac7a5451e8e92a32e22a60d86882d6a034f3f",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1071,11 +1060,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751856221,
|
"lastModified": 1759113356,
|
||||||
"narHash": "sha256-/QE1eV0ckFvgRMcKjZqgdJDoXFNwSMepwRoBjaw2MCk=",
|
"narHash": "sha256-xm4kEUcV2jk6u15aHazFP4YsMwhq+PczA+Ul/4FDKWI=",
|
||||||
"owner": "oxalica",
|
"owner": "oxalica",
|
||||||
"repo": "rust-overlay",
|
"repo": "rust-overlay",
|
||||||
"rev": "34cae4b56929c5b340e1c5b10d9a98a425b2a51e",
|
"rev": "be3b8843a2be2411500f6c052876119485e957a2",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1091,15 +1080,16 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751606940,
|
"lastModified": 1759191583,
|
||||||
"narHash": "sha256-KrDPXobG7DFKTOteqdSVeL1bMVitDcy7otpVZWDE6MA=",
|
"narHash": "sha256-gO4oCYU9TSoqtQzUqI8aiotKEhcObTEBXE5M2RRAsT8=",
|
||||||
"owner": "Mic92",
|
"owner": "Mic92",
|
||||||
"repo": "sops-nix",
|
"repo": "sops-nix",
|
||||||
"rev": "3633fc4acf03f43b260244d94c71e9e14a2f6e0d",
|
"rev": "9f2e820c1643e55e88e83481e234dcf08143f3cf",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "Mic92",
|
"owner": "Mic92",
|
||||||
|
"ref": "pull/779/merge",
|
||||||
"repo": "sops-nix",
|
"repo": "sops-nix",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -1111,12 +1101,12 @@
|
|||||||
"base16-helix": "base16-helix",
|
"base16-helix": "base16-helix",
|
||||||
"base16-vim": "base16-vim",
|
"base16-vim": "base16-vim",
|
||||||
"firefox-gnome-theme": "firefox-gnome-theme",
|
"firefox-gnome-theme": "firefox-gnome-theme",
|
||||||
"flake-parts": "flake-parts_4",
|
"flake-parts": "flake-parts_3",
|
||||||
"gnome-shell": "gnome-shell",
|
"gnome-shell": "gnome-shell",
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
],
|
],
|
||||||
"nur": "nur_2",
|
"nur": "nur",
|
||||||
"systems": "systems_2",
|
"systems": "systems_2",
|
||||||
"tinted-foot": "tinted-foot",
|
"tinted-foot": "tinted-foot",
|
||||||
"tinted-kitty": "tinted-kitty",
|
"tinted-kitty": "tinted-kitty",
|
||||||
@@ -1125,11 +1115,11 @@
|
|||||||
"tinted-zed": "tinted-zed"
|
"tinted-zed": "tinted-zed"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752201883,
|
"lastModified": 1759131326,
|
||||||
"narHash": "sha256-SZVbQ4YThvYU50cJ4W4GNMy7/rVOJI8qmXqbEcRNsug=",
|
"narHash": "sha256-fFhUx2C0Wtz0YkndtnlpSesrqj4lP3d5BUnMprpXtTk=",
|
||||||
"owner": "danth",
|
"owner": "danth",
|
||||||
"repo": "stylix",
|
"repo": "stylix",
|
||||||
"rev": "d395780b9c5c36f191b990b2021c71af180a1982",
|
"rev": "fe74ba4ade9f3bb1496fbff27cc7a0ca873e40c4",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1204,11 +1194,11 @@
|
|||||||
"tinted-schemes": {
|
"tinted-schemes": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1750770351,
|
"lastModified": 1757716333,
|
||||||
"narHash": "sha256-LI+BnRoFNRa2ffbe3dcuIRYAUcGklBx0+EcFxlHj0SY=",
|
"narHash": "sha256-d4km8W7w2zCUEmPAPUoLk1NlYrGODuVa3P7St+UrqkM=",
|
||||||
"owner": "tinted-theming",
|
"owner": "tinted-theming",
|
||||||
"repo": "schemes",
|
"repo": "schemes",
|
||||||
"rev": "5a775c6ffd6e6125947b393872cde95867d85a2a",
|
"rev": "317a5e10c35825a6c905d912e480dfe8e71c7559",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1220,11 +1210,11 @@
|
|||||||
"tinted-tmux": {
|
"tinted-tmux": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751159871,
|
"lastModified": 1757811970,
|
||||||
"narHash": "sha256-UOHBN1fgHIEzvPmdNMHaDvdRMgLmEJh2hNmDrp3d3LE=",
|
"narHash": "sha256-n5ZJgmzGZXOD9pZdAl1OnBu3PIqD+X3vEBUGbTi4JiI=",
|
||||||
"owner": "tinted-theming",
|
"owner": "tinted-theming",
|
||||||
"repo": "tinted-tmux",
|
"repo": "tinted-tmux",
|
||||||
"rev": "bded5e24407cec9d01bd47a317d15b9223a1546c",
|
"rev": "d217ba31c846006e9e0ae70775b0ee0f00aa6b1e",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1236,11 +1226,11 @@
|
|||||||
"tinted-zed": {
|
"tinted-zed": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751158968,
|
"lastModified": 1757811247,
|
||||||
"narHash": "sha256-ksOyv7D3SRRtebpXxgpG4TK8gZSKFc4TIZpR+C98jX8=",
|
"narHash": "sha256-4EFOUyLj85NRL3OacHoLGEo0wjiRJzfsXtR4CZWAn6w=",
|
||||||
"owner": "tinted-theming",
|
"owner": "tinted-theming",
|
||||||
"repo": "base16-zed",
|
"repo": "base16-zed",
|
||||||
"rev": "86a470d94204f7652b906ab0d378e4231a5b3384",
|
"rev": "824fe0aacf82b3c26690d14e8d2cedd56e18404e",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1252,16 +1242,16 @@
|
|||||||
"xwayland-satellite-stable": {
|
"xwayland-satellite-stable": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1748488455,
|
"lastModified": 1755491097,
|
||||||
"narHash": "sha256-IiLr1alzKFIy5tGGpDlabQbe6LV1c9ABvkH6T5WmyRI=",
|
"narHash": "sha256-m+9tUfsmBeF2Gn4HWa6vSITZ4Gz1eA1F5Kh62B0N4oE=",
|
||||||
"owner": "Supreeeme",
|
"owner": "Supreeeme",
|
||||||
"repo": "xwayland-satellite",
|
"repo": "xwayland-satellite",
|
||||||
"rev": "3ba30b149f9eb2bbf42cf4758d2158ca8cceef73",
|
"rev": "388d291e82ffbc73be18169d39470f340707edaa",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "Supreeeme",
|
"owner": "Supreeeme",
|
||||||
"ref": "v0.6",
|
"ref": "v0.7",
|
||||||
"repo": "xwayland-satellite",
|
"repo": "xwayland-satellite",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
@@ -1269,11 +1259,11 @@
|
|||||||
"xwayland-satellite-unstable": {
|
"xwayland-satellite-unstable": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1751228685,
|
"lastModified": 1758577423,
|
||||||
"narHash": "sha256-MENtauGBhJ+kDeFaawvWGXaFG3Il6qQzjaP0RmtfM0k=",
|
"narHash": "sha256-sB2GAOjhjoWnjU6A/uHNJiY6O3UeztV5pJAN2g1FkXU=",
|
||||||
"owner": "Supreeeme",
|
"owner": "Supreeeme",
|
||||||
"repo": "xwayland-satellite",
|
"repo": "xwayland-satellite",
|
||||||
"rev": "557ebeb616e03d5e4a8049862bbbd1f02c6f020b",
|
"rev": "03368548ba745e17a85bd631613a59cb2d8469a4",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@@ -1290,11 +1280,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1752164817,
|
"lastModified": 1759292536,
|
||||||
"narHash": "sha256-LJFIx27IOUowLsJn5wci9mHZ4CesJsiAivQWDjnZPCc=",
|
"narHash": "sha256-fWTojLEpXgqwtKZb+qJ5gn9y8N6MAKM35yu0k+4yWmo=",
|
||||||
"owner": "0xc000022070",
|
"owner": "0xc000022070",
|
||||||
"repo": "zen-browser-flake",
|
"repo": "zen-browser-flake",
|
||||||
"rev": "9193992c4c2c4349b4280ec2b49648cae208fe63",
|
"rev": "d11cff279fb1d879cd72d6fb3bbd1ae7b584674b",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|||||||
52
flake.nix
52
flake.nix
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
# Nixpkgs
|
# Nixpkgs
|
||||||
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable-small";
|
nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||||
nixpkgs-stable.url = "github:nixos/nixpkgs/release-25.05";
|
nixpkgs-stable.url = "github:nixos/nixpkgs/release-25.05";
|
||||||
nixpkgs-master.url = "github:nixos/nixpkgs/master";
|
nixpkgs-master.url = "github:nixos/nixpkgs/master";
|
||||||
# nixpkgs.follows = "nixpkgs-stable";
|
# nixpkgs.follows = "nixpkgs-stable";
|
||||||
@@ -13,8 +13,9 @@
|
|||||||
# Nyxpkgs
|
# Nyxpkgs
|
||||||
chaotic.url = "github:chaotic-cx/nyx/nyxpkgs-unstable";
|
chaotic.url = "github:chaotic-cx/nyx/nyxpkgs-unstable";
|
||||||
|
|
||||||
# SOPS
|
# TODO: sops-nix: remove pr patch once merged
|
||||||
sops-nix.url = "github:Mic92/sops-nix";
|
# https://github.com/Mic92/sops-nix/pull/779
|
||||||
|
sops-nix.url = "github:Mic92/sops-nix/pull/779/merge";
|
||||||
sops-nix.inputs.nixpkgs.follows = "nixpkgs";
|
sops-nix.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
|
||||||
# Home manager
|
# Home manager
|
||||||
@@ -24,16 +25,8 @@
|
|||||||
# Impermanence
|
# Impermanence
|
||||||
impermanence.url = "github:nix-community/impermanence";
|
impermanence.url = "github:nix-community/impermanence";
|
||||||
|
|
||||||
# NUR
|
|
||||||
nur.url = "github:nix-community/NUR";
|
|
||||||
|
|
||||||
# Niri
|
# Niri
|
||||||
niri.url = "github:sodiboo/niri-flake";
|
niri.url = "github:sodiboo/niri-flake";
|
||||||
niri.inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
niri.inputs.nixpkgs-stable.follows = "nixpkgs-stable";
|
|
||||||
|
|
||||||
quickshell.url = "git+https://git.outfoxxed.me/outfoxxed/quickshell";
|
|
||||||
quickshell.inputs.nixpkgs.follows = "nixpkgs";
|
|
||||||
|
|
||||||
darkly.url = "github:Bali10050/Darkly";
|
darkly.url = "github:Bali10050/Darkly";
|
||||||
darkly.inputs.nixpkgs.follows = "nixpkgs";
|
darkly.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
@@ -55,6 +48,12 @@
|
|||||||
zen.url = "github:0xc000022070/zen-browser-flake";
|
zen.url = "github:0xc000022070/zen-browser-flake";
|
||||||
zen.inputs.nixpkgs.follows = "nixpkgs";
|
zen.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
|
||||||
|
plant.url = "git+ssh://git@git.imxyy.top:2222/imxyy1soope1/HF-plant.git?rev=08dc0b3889797eb3618c7475c3c367ec0e5fdf40";
|
||||||
|
plant.flake = false;
|
||||||
|
|
||||||
|
catppuccin.url = "github:catppuccin/nix";
|
||||||
|
catppuccin.inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
|
||||||
infuse.url = "git+https://codeberg.org/amjoseph/infuse.nix";
|
infuse.url = "git+https://codeberg.org/amjoseph/infuse.nix";
|
||||||
infuse.flake = false;
|
infuse.flake = false;
|
||||||
|
|
||||||
@@ -71,10 +70,10 @@
|
|||||||
let
|
let
|
||||||
inherit (self) outputs;
|
inherit (self) outputs;
|
||||||
vars = import ./vars.nix;
|
vars = import ./vars.nix;
|
||||||
forAllSystems = nixpkgs.lib.genAttrs nixpkgs.lib.systems.flakeExposed;
|
forAllSystems = lib.genAttrs lib.systems.flakeExposed;
|
||||||
forAllHosts =
|
forAllHosts =
|
||||||
mkSystem:
|
mkSystem:
|
||||||
nixpkgs.lib.attrsets.mergeAttrsList (
|
lib.mergeAttrsList (
|
||||||
builtins.map (hostname: {
|
builtins.map (hostname: {
|
||||||
${hostname} = mkSystem hostname;
|
${hostname} = mkSystem hostname;
|
||||||
}) (builtins.attrNames (builtins.readDir ./config/hosts))
|
}) (builtins.attrNames (builtins.readDir ./config/hosts))
|
||||||
@@ -139,17 +138,6 @@
|
|||||||
darkly-qt5 = inputs.darkly.packages.${final.system}.darkly-qt5;
|
darkly-qt5 = inputs.darkly.packages.${final.system}.darkly-qt5;
|
||||||
darkly-qt6 = inputs.darkly.packages.${final.system}.darkly-qt6;
|
darkly-qt6 = inputs.darkly.packages.${final.system}.darkly-qt6;
|
||||||
})
|
})
|
||||||
(final: prev: {
|
|
||||||
quickshell = inputs.quickshell.packages.${final.system}.default.override {
|
|
||||||
withJemalloc = true;
|
|
||||||
withQtSvg = true;
|
|
||||||
withWayland = true;
|
|
||||||
withPipewire = true;
|
|
||||||
withPam = false;
|
|
||||||
withX11 = false;
|
|
||||||
withHyprland = false;
|
|
||||||
};
|
|
||||||
})
|
|
||||||
(final: prev: {
|
(final: prev: {
|
||||||
inherit lib;
|
inherit lib;
|
||||||
})
|
})
|
||||||
@@ -185,9 +173,16 @@
|
|||||||
outputs
|
outputs
|
||||||
hostname
|
hostname
|
||||||
;
|
;
|
||||||
sopsRoot = ./secrets;
|
secrets =
|
||||||
flake = ./.;
|
with lib.haumea;
|
||||||
} // vars;
|
load {
|
||||||
|
src = ./secrets;
|
||||||
|
loader = [
|
||||||
|
(matchers.always loaders.path)
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
|
// vars;
|
||||||
modules =
|
modules =
|
||||||
(lib.umport {
|
(lib.umport {
|
||||||
paths = [ ./modules ];
|
paths = [ ./modules ];
|
||||||
@@ -198,7 +193,7 @@
|
|||||||
recursive = true;
|
recursive = true;
|
||||||
})
|
})
|
||||||
++ [
|
++ [
|
||||||
(lib.mkAliasOptionModule [ "my" "home" ] [ "home-manager" "users" vars.username ])
|
(lib.mkAliasOptionModule [ "my" "hm" ] [ "home-manager" "users" vars.username ])
|
||||||
./config/base.nix
|
./config/base.nix
|
||||||
./config/hosts/${hostname}
|
./config/hosts/${hostname}
|
||||||
inputs.chaotic.nixosModules.default
|
inputs.chaotic.nixosModules.default
|
||||||
@@ -206,6 +201,7 @@
|
|||||||
inputs.impermanence.nixosModules.impermanence
|
inputs.impermanence.nixosModules.impermanence
|
||||||
inputs.home-manager.nixosModules.default
|
inputs.home-manager.nixosModules.default
|
||||||
inputs.niri.nixosModules.niri
|
inputs.niri.nixosModules.niri
|
||||||
|
inputs.catppuccin.nixosModules.catppuccin
|
||||||
home
|
home
|
||||||
pkgsConf
|
pkgsConf
|
||||||
];
|
];
|
||||||
|
|||||||
@@ -36,7 +36,7 @@
|
|||||||
optionName = packageName;
|
optionName = packageName;
|
||||||
config' = lib.mkMerge [
|
config' = lib.mkMerge [
|
||||||
{
|
{
|
||||||
my.home.home.packages = [ (lib.getAttrFromPath packagePath pkgs) ];
|
my.hm.home.packages = [ (lib.getAttrFromPath packagePath pkgs) ];
|
||||||
}
|
}
|
||||||
extraConfig
|
extraConfig
|
||||||
];
|
];
|
||||||
@@ -55,7 +55,7 @@
|
|||||||
|
|
||||||
config' = lib.mkMerge [
|
config' = lib.mkMerge [
|
||||||
{
|
{
|
||||||
my.home.programs = lib.setAttrByPath [ programName "enable" ] true;
|
my.hm.programs = lib.setAttrByPath [ programName "enable" ] true;
|
||||||
}
|
}
|
||||||
extraConfig
|
extraConfig
|
||||||
];
|
];
|
||||||
|
|||||||
26
modules/audio.nix
Normal file
26
modules/audio.nix
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
username,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
lib.my.makeSwitch {
|
||||||
|
inherit config;
|
||||||
|
default = true;
|
||||||
|
optionName = "default audio settings";
|
||||||
|
optionPath = [ "audio" ];
|
||||||
|
config' = {
|
||||||
|
security.rtkit.enable = true;
|
||||||
|
services.pipewire = {
|
||||||
|
enable = true;
|
||||||
|
alsa.enable = true;
|
||||||
|
alsa.support32Bit = true;
|
||||||
|
pulse.enable = true;
|
||||||
|
audio.enable = true;
|
||||||
|
};
|
||||||
|
users.extraUsers.${username}.extraGroups = [ "audio" ];
|
||||||
|
my.persist.homeDirs = [ ".local/state/wireplumber" ];
|
||||||
|
my.hm.home.packages = [ pkgs.pwvucontrol ];
|
||||||
|
};
|
||||||
|
}
|
||||||
20
modules/bluetooth.nix
Normal file
20
modules/bluetooth.nix
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{ config, lib, ... }:
|
||||||
|
lib.my.makeSwitch {
|
||||||
|
inherit config;
|
||||||
|
default = true;
|
||||||
|
optionName = "default bluetooth settings";
|
||||||
|
optionPath = [ "bluetooth" ];
|
||||||
|
config' = {
|
||||||
|
hardware.bluetooth = {
|
||||||
|
enable = true;
|
||||||
|
powerOnBoot = true;
|
||||||
|
settings = {
|
||||||
|
General = {
|
||||||
|
Enable = "Source,Sink,Media,Socket";
|
||||||
|
Disable = "HeadSet";
|
||||||
|
MultiProfile = "multiple";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -9,7 +9,6 @@ lib.my.makeSwitch {
|
|||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.cli.media = {
|
my.cli.media = {
|
||||||
cava.enable = true;
|
|
||||||
go-musicfox.enable = true;
|
go-musicfox.enable = true;
|
||||||
mpd.enable = true;
|
mpd.enable = true;
|
||||||
ffmpeg.enable = true;
|
ffmpeg.enable = true;
|
||||||
|
|||||||
@@ -1,167 +0,0 @@
|
|||||||
## Configuration file for CAVA. Default values are commented out. Use either ';' or '#' for commenting.
|
|
||||||
|
|
||||||
|
|
||||||
[general]
|
|
||||||
|
|
||||||
# Smoothing mode. Can be 'normal', 'scientific' or 'waves'.
|
|
||||||
mode = normal
|
|
||||||
|
|
||||||
# Accepts only non-negative values.
|
|
||||||
framerate = 60
|
|
||||||
|
|
||||||
# 'autosens' will attempt to decrease sensitivity if the bars peak. 1 = on, 0 = off
|
|
||||||
# 'overshoot' allows bars to overshoot (in % of terminal height) without initiating autosens.
|
|
||||||
; autosens = 1
|
|
||||||
; overshoot = 20
|
|
||||||
|
|
||||||
# Manual sensitivity in %. Autosens must be turned off for this to take effect.
|
|
||||||
# 200 means double height. Accepts only non-negative values.
|
|
||||||
; sensitivity = 100
|
|
||||||
|
|
||||||
# The number of bars (0-200). 0 sets it to auto (fill up console).
|
|
||||||
# Bars' width and space between bars in number of characters.
|
|
||||||
bars = 0
|
|
||||||
bar_width = 5
|
|
||||||
bar_spacing = 1
|
|
||||||
|
|
||||||
# Lower and higher cutoff frequencies for lowest and highest bars
|
|
||||||
# the bandwidth of the visualizer.
|
|
||||||
# Note: there is a minimum total bandwidth of 43Mhz x number of bars.
|
|
||||||
# Cava will automatically increase the higher cutoff if a too low band is specified.
|
|
||||||
; lower_cutoff_freq = 50
|
|
||||||
; higher_cutoff_freq = 10000
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[input]
|
|
||||||
|
|
||||||
# Audio capturing method. Possible methods are: 'pulse', 'alsa' or 'fifo'.
|
|
||||||
# Defaults to 'pulse', 'alsa' or 'fifo', in that order, dependent on what support cava was built with.
|
|
||||||
#
|
|
||||||
# All input methods uses the same config variable 'source'
|
|
||||||
# to define where it should get the audio.
|
|
||||||
#
|
|
||||||
# For pulseaudio 'source' will be the source. Default: 'auto', which uses the monitor source of the default sink
|
|
||||||
# (all pulseaudio sinks(outputs) have 'monitor' sources(inputs) associated with them).
|
|
||||||
#
|
|
||||||
# For alsa 'source' will be the capture device.
|
|
||||||
# For fifo 'source' will be the path to fifo-file.
|
|
||||||
method = pulse
|
|
||||||
source = auto
|
|
||||||
|
|
||||||
; method = alsa
|
|
||||||
; source = hw:Loopback,1
|
|
||||||
|
|
||||||
; method = fifo
|
|
||||||
; source = /tmp/mpd.fifo
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[output]
|
|
||||||
|
|
||||||
# Ouput method. Can be 'ncurses', 'noncurses' or 'raw'.
|
|
||||||
# 'noncurses' is for systems that does not suport ncurses.
|
|
||||||
# 'raw' is a 16 bit data stream of the bar heights that can be used to send to other applications.
|
|
||||||
# 'raw' defaults to 200 bars, which can be adjusted in the 'bars' option above.
|
|
||||||
method = ncurses
|
|
||||||
|
|
||||||
# Visual styles. Can be 'stereo' or 'mono'.
|
|
||||||
# 'stereo' mirrors both channels with low frequencies in center.
|
|
||||||
# 'mono' averages both channels and outputs left to right lowest to highest frequencies.
|
|
||||||
style = mono
|
|
||||||
|
|
||||||
# Raw output target. A fifo will be created if target does not exist.
|
|
||||||
; raw_target = /dev/stdout
|
|
||||||
|
|
||||||
# Raw data format. Can be 'binary' or 'ascii'.
|
|
||||||
; data_format = binary
|
|
||||||
|
|
||||||
# Binary bit format, can be '8bit' (0-255) or '16bit' (0-65530).
|
|
||||||
; bit_format = 16bit
|
|
||||||
|
|
||||||
# Ascii max value. In 'ascii' mode range will run from 0 to value specified here
|
|
||||||
; ascii_max_range = 1000
|
|
||||||
|
|
||||||
# Ascii delimiters. In ascii format each bar and frame is separated by a delimiters.
|
|
||||||
# Use decimal value in ascii table (i.e. 59 = ';' and 10 = '\n' (line feed)).
|
|
||||||
; bar_delimiter = 59
|
|
||||||
; frame_delimiter = 10
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# [color]
|
|
||||||
|
|
||||||
# # Colors can be one of seven predefined: black, blue, cyan, green, magenta, red, white, yellow.
|
|
||||||
# # Or defined by hex code '#xxxxxx' (hex code must be within ''). User defined colors requires a
|
|
||||||
# # terminal that can change color definitions such as Gnome-terminal or rxvt.
|
|
||||||
# ; background = black
|
|
||||||
# ; foreground = cyan
|
|
||||||
|
|
||||||
# # Gradient mode, only hex defined colors are supported, background must also be defined in hex
|
|
||||||
# # or remain commented out. 1 = on, 0 = off. Warning: for certain terminal emulators cava will
|
|
||||||
# # not able to restore color definitions on exit, simply restart your terminal to restore colors.
|
|
||||||
# gradient = 1
|
|
||||||
# gradient_color_1 = '#0099ff'
|
|
||||||
# gradient_color_2 = '#ff3399'
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[smoothing]
|
|
||||||
|
|
||||||
# Multiplier for the integral smoothing calculations. Takes values from 0-0.99.
|
|
||||||
# Higher values means smoother, but less precise. Set to 0 to disable.
|
|
||||||
; integral = 0.7
|
|
||||||
|
|
||||||
# Disables or enables the so-called "Monstercat smoothing". Set to 0 to disable.
|
|
||||||
; monstercat = 1
|
|
||||||
; waves = 1
|
|
||||||
|
|
||||||
# Set gravity multiplier for "drop off". Higher values means bars will drop faster.
|
|
||||||
# Accepts only non-negative values. 0.5 means half gravity, 2 means double. Set to 0 to disable "drop off".
|
|
||||||
; gravity = 2
|
|
||||||
|
|
||||||
|
|
||||||
# In bar height, bars that would have been lower that this will not be drawn.
|
|
||||||
; ignore = 0
|
|
||||||
|
|
||||||
|
|
||||||
[eq]
|
|
||||||
|
|
||||||
# This one is tricky. You can have as much keys as you want.
|
|
||||||
# Remember to uncomment more then one key! More keys = more precision.
|
|
||||||
# Look at readme.md on github for further explanations and examples.
|
|
||||||
#; 1 = 1 # bass
|
|
||||||
#; 2 = 1
|
|
||||||
#; 3 = 1 # midtone
|
|
||||||
#; 4 = 1
|
|
||||||
#; 5 = 1 # treble
|
|
||||||
1=1
|
|
||||||
2=1
|
|
||||||
3=2
|
|
||||||
4=1
|
|
||||||
5=1
|
|
||||||
|
|
||||||
[color]
|
|
||||||
|
|
||||||
#background = '#191724'
|
|
||||||
gradient = 1
|
|
||||||
gradient_count = 6
|
|
||||||
gradient_color_1 = '#31748f'
|
|
||||||
gradient_color_2 = '#9ccfd8'
|
|
||||||
gradient_color_3 = '#c4a7e7'
|
|
||||||
gradient_color_4 = '#ebbcba'
|
|
||||||
gradient_color_5 = '#f6c177'
|
|
||||||
gradient_color_6 = '#eb6f92'
|
|
||||||
|
|
||||||
[color]
|
|
||||||
|
|
||||||
gradient = 1
|
|
||||||
|
|
||||||
gradient_color_1 = '#94e2d5'
|
|
||||||
gradient_color_2 = '#89dceb'
|
|
||||||
gradient_color_3 = '#74c7ec'
|
|
||||||
gradient_color_4 = '#89b4fa'
|
|
||||||
gradient_color_5 = '#cba6f7'
|
|
||||||
gradient_color_6 = '#f5c2e7'
|
|
||||||
gradient_color_7 = '#eba0ac'
|
|
||||||
gradient_color_8 = '#f38ba8'
|
|
||||||
@@ -1,167 +0,0 @@
|
|||||||
## Configuration file for CAVA. Default values are commented out. Use either ';' or '#' for commenting.
|
|
||||||
|
|
||||||
|
|
||||||
[general]
|
|
||||||
|
|
||||||
# Smoothing mode. Can be 'normal', 'scientific' or 'waves'.
|
|
||||||
mode = normal
|
|
||||||
|
|
||||||
# Accepts only non-negative values.
|
|
||||||
framerate = 60
|
|
||||||
|
|
||||||
# 'autosens' will attempt to decrease sensitivity if the bars peak. 1 = on, 0 = off
|
|
||||||
# 'overshoot' allows bars to overshoot (in % of terminal height) without initiating autosens.
|
|
||||||
; autosens = 1
|
|
||||||
; overshoot = 20
|
|
||||||
|
|
||||||
# Manual sensitivity in %. Autosens must be turned off for this to take effect.
|
|
||||||
# 200 means double height. Accepts only non-negative values.
|
|
||||||
; sensitivity = 100
|
|
||||||
|
|
||||||
# The number of bars (0-200). 0 sets it to auto (fill up console).
|
|
||||||
# Bars' width and space between bars in number of characters.
|
|
||||||
bars = 0
|
|
||||||
bar_width = 2
|
|
||||||
bar_spacing = 1
|
|
||||||
|
|
||||||
# Lower and higher cutoff frequencies for lowest and highest bars
|
|
||||||
# the bandwidth of the visualizer.
|
|
||||||
# Note: there is a minimum total bandwidth of 43Mhz x number of bars.
|
|
||||||
# Cava will automatically increase the higher cutoff if a too low band is specified.
|
|
||||||
; lower_cutoff_freq = 50
|
|
||||||
; higher_cutoff_freq = 10000
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[input]
|
|
||||||
|
|
||||||
# Audio capturing method. Possible methods are: 'pulse', 'alsa' or 'fifo'.
|
|
||||||
# Defaults to 'pulse', 'alsa' or 'fifo', in that order, dependent on what support cava was built with.
|
|
||||||
#
|
|
||||||
# All input methods uses the same config variable 'source'
|
|
||||||
# to define where it should get the audio.
|
|
||||||
#
|
|
||||||
# For pulseaudio 'source' will be the source. Default: 'auto', which uses the monitor source of the default sink
|
|
||||||
# (all pulseaudio sinks(outputs) have 'monitor' sources(inputs) associated with them).
|
|
||||||
#
|
|
||||||
# For alsa 'source' will be the capture device.
|
|
||||||
# For fifo 'source' will be the path to fifo-file.
|
|
||||||
method = pulse
|
|
||||||
source = auto
|
|
||||||
|
|
||||||
; method = alsa
|
|
||||||
; source = hw:Loopback,1
|
|
||||||
|
|
||||||
; method = fifo
|
|
||||||
; source = /tmp/mpd.fifo
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[output]
|
|
||||||
|
|
||||||
# Ouput method. Can be 'ncurses', 'noncurses' or 'raw'.
|
|
||||||
# 'noncurses' is for systems that does not suport ncurses.
|
|
||||||
# 'raw' is a 16 bit data stream of the bar heights that can be used to send to other applications.
|
|
||||||
# 'raw' defaults to 200 bars, which can be adjusted in the 'bars' option above.
|
|
||||||
method = ncurses
|
|
||||||
|
|
||||||
# Visual styles. Can be 'stereo' or 'mono'.
|
|
||||||
# 'stereo' mirrors both channels with low frequencies in center.
|
|
||||||
# 'mono' averages both channels and outputs left to right lowest to highest frequencies.
|
|
||||||
style = mono
|
|
||||||
|
|
||||||
# Raw output target. A fifo will be created if target does not exist.
|
|
||||||
; raw_target = /dev/stdout
|
|
||||||
|
|
||||||
# Raw data format. Can be 'binary' or 'ascii'.
|
|
||||||
; data_format = binary
|
|
||||||
|
|
||||||
# Binary bit format, can be '8bit' (0-255) or '16bit' (0-65530).
|
|
||||||
; bit_format = 16bit
|
|
||||||
|
|
||||||
# Ascii max value. In 'ascii' mode range will run from 0 to value specified here
|
|
||||||
; ascii_max_range = 1000
|
|
||||||
|
|
||||||
# Ascii delimiters. In ascii format each bar and frame is separated by a delimiters.
|
|
||||||
# Use decimal value in ascii table (i.e. 59 = ';' and 10 = '\n' (line feed)).
|
|
||||||
; bar_delimiter = 59
|
|
||||||
; frame_delimiter = 10
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# [color]
|
|
||||||
|
|
||||||
# # Colors can be one of seven predefined: black, blue, cyan, green, magenta, red, white, yellow.
|
|
||||||
# # Or defined by hex code '#xxxxxx' (hex code must be within ''). User defined colors requires a
|
|
||||||
# # terminal that can change color definitions such as Gnome-terminal or rxvt.
|
|
||||||
# ; background = black
|
|
||||||
# ; foreground = cyan
|
|
||||||
|
|
||||||
# # Gradient mode, only hex defined colors are supported, background must also be defined in hex
|
|
||||||
# # or remain commented out. 1 = on, 0 = off. Warning: for certain terminal emulators cava will
|
|
||||||
# # not able to restore color definitions on exit, simply restart your terminal to restore colors.
|
|
||||||
# gradient = 1
|
|
||||||
# gradient_color_1 = '#0099ff'
|
|
||||||
# gradient_color_2 = '#ff3399'
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[smoothing]
|
|
||||||
|
|
||||||
# Multiplier for the integral smoothing calculations. Takes values from 0-0.99.
|
|
||||||
# Higher values means smoother, but less precise. Set to 0 to disable.
|
|
||||||
; integral = 0.7
|
|
||||||
|
|
||||||
# Disables or enables the so-called "Monstercat smoothing". Set to 0 to disable.
|
|
||||||
; monstercat = 1
|
|
||||||
; waves = 1
|
|
||||||
|
|
||||||
# Set gravity multiplier for "drop off". Higher values means bars will drop faster.
|
|
||||||
# Accepts only non-negative values. 0.5 means half gravity, 2 means double. Set to 0 to disable "drop off".
|
|
||||||
; gravity = 1
|
|
||||||
|
|
||||||
|
|
||||||
# In bar height, bars that would have been lower that this will not be drawn.
|
|
||||||
; ignore = 0
|
|
||||||
|
|
||||||
|
|
||||||
[eq]
|
|
||||||
|
|
||||||
# This one is tricky. You can have as much keys as you want.
|
|
||||||
# Remember to uncomment more then one key! More keys = more precision.
|
|
||||||
# Look at readme.md on github for further explanations and examples.
|
|
||||||
#; 1 = 1 # bass
|
|
||||||
#; 2 = 1
|
|
||||||
#; 3 = 1 # midtone
|
|
||||||
#; 4 = 1
|
|
||||||
#; 5 = 1 # treble
|
|
||||||
1=1
|
|
||||||
2=1
|
|
||||||
3=2
|
|
||||||
4=1
|
|
||||||
5=1
|
|
||||||
|
|
||||||
[color]
|
|
||||||
|
|
||||||
#background = '#191724'
|
|
||||||
gradient = 1
|
|
||||||
gradient_count = 6
|
|
||||||
gradient_color_1 = '#31748f'
|
|
||||||
gradient_color_2 = '#9ccfd8'
|
|
||||||
gradient_color_3 = '#c4a7e7'
|
|
||||||
gradient_color_4 = '#ebbcba'
|
|
||||||
gradient_color_5 = '#f6c177'
|
|
||||||
gradient_color_6 = '#eb6f92'
|
|
||||||
|
|
||||||
[color]
|
|
||||||
|
|
||||||
gradient = 1
|
|
||||||
|
|
||||||
gradient_color_1 = '#94e2d5'
|
|
||||||
gradient_color_2 = '#89dceb'
|
|
||||||
gradient_color_3 = '#74c7ec'
|
|
||||||
gradient_color_4 = '#89b4fa'
|
|
||||||
gradient_color_5 = '#cba6f7'
|
|
||||||
gradient_color_6 = '#f5c2e7'
|
|
||||||
gradient_color_7 = '#eba0ac'
|
|
||||||
gradient_color_8 = '#f38ba8'
|
|
||||||
@@ -1,79 +0,0 @@
|
|||||||
#version 330
|
|
||||||
|
|
||||||
in vec2 fragCoord;
|
|
||||||
out vec4 fragColor;
|
|
||||||
|
|
||||||
// bar values. defaults to left channels first (low to high), then right (high to low).
|
|
||||||
uniform float bars[512];
|
|
||||||
|
|
||||||
uniform int bars_count; // number of bars (left + right) (configurable)
|
|
||||||
uniform int bar_width; // bar width (configurable), not used here
|
|
||||||
uniform int bar_spacing; // space bewteen bars (configurable)
|
|
||||||
|
|
||||||
uniform vec3 u_resolution; // window resolution
|
|
||||||
|
|
||||||
//colors, configurable in cava config file (r,g,b) (0.0 - 1.0)
|
|
||||||
uniform vec3 bg_color; // background color
|
|
||||||
uniform vec3 fg_color; // foreground color
|
|
||||||
|
|
||||||
uniform int gradient_count;
|
|
||||||
uniform vec3 gradient_colors[8]; // gradient colors
|
|
||||||
|
|
||||||
vec3 normalize_C(float y,vec3 col_1, vec3 col_2, float y_min, float y_max)
|
|
||||||
{
|
|
||||||
//create color based on fraction of this color and next color
|
|
||||||
float yr = (y - y_min) / (y_max - y_min);
|
|
||||||
return col_1 * (1.0 - yr) + col_2 * yr;
|
|
||||||
}
|
|
||||||
|
|
||||||
void main()
|
|
||||||
{
|
|
||||||
// find which bar to use based on where we are on the x axis
|
|
||||||
float x = u_resolution.x * fragCoord.x;
|
|
||||||
int bar = int(bars_count * fragCoord.x);
|
|
||||||
|
|
||||||
//calculate a bar size
|
|
||||||
float bar_size = u_resolution.x / bars_count;
|
|
||||||
|
|
||||||
//the y coordinate and bar values are the same
|
|
||||||
float y = bars[bar];
|
|
||||||
|
|
||||||
// make sure there is a thin line at bottom
|
|
||||||
if (y * u_resolution.y < 1.0)
|
|
||||||
{
|
|
||||||
y = 1.0 / u_resolution.y;
|
|
||||||
}
|
|
||||||
|
|
||||||
//draw the bar up to current height
|
|
||||||
if (y > fragCoord.y)
|
|
||||||
{
|
|
||||||
//make some space between bars basen on settings
|
|
||||||
if (x > (bar + 1) * (bar_size) - bar_spacing)
|
|
||||||
{
|
|
||||||
fragColor = vec4(bg_color,1.0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (gradient_count == 0)
|
|
||||||
{
|
|
||||||
fragColor = vec4(fg_color,1.0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//find which color in the configured gradient we are at
|
|
||||||
int color = int((gradient_count - 1) * fragCoord.y);
|
|
||||||
|
|
||||||
//find where on y this and next color is supposed to be
|
|
||||||
float y_min = color / (gradient_count - 1.0);
|
|
||||||
float y_max = (color + 1.0) / (gradient_count - 1.0);
|
|
||||||
|
|
||||||
//make color
|
|
||||||
fragColor = vec4(normalize_C(fragCoord.y, gradient_colors[color], gradient_colors[color + 1], y_min, y_max), 1.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
fragColor = vec4(bg_color,1.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
#version 330
|
|
||||||
|
|
||||||
in vec2 fragCoord;
|
|
||||||
out vec4 fragColor;
|
|
||||||
|
|
||||||
// bar values. defaults to left channels first (low to high), then right (high to low).
|
|
||||||
uniform float bars[512];
|
|
||||||
|
|
||||||
uniform int bars_count; // number of bars (left + right) (configurable)
|
|
||||||
|
|
||||||
uniform vec3 u_resolution; // window resolution, not used here
|
|
||||||
|
|
||||||
//colors, configurable in cava config file
|
|
||||||
uniform vec3 bg_color; // background color(r,g,b) (0.0 - 1.0), not used here
|
|
||||||
uniform vec3 fg_color; // foreground color, not used here
|
|
||||||
|
|
||||||
float normalize_C(float x, float x_min, float x_max, float r_min, float r_max )
|
|
||||||
{
|
|
||||||
float xr;
|
|
||||||
xr = (r_max-r_min) * (x - x_min) / (x_max - x_min) + r_min;
|
|
||||||
return xr;
|
|
||||||
}
|
|
||||||
|
|
||||||
void main()
|
|
||||||
{
|
|
||||||
// find which bar to use based on where we are on the x axis
|
|
||||||
int bar = int(bars_count * fragCoord.x);
|
|
||||||
|
|
||||||
// create a normal along the y axis based on the bar height
|
|
||||||
float x = normalize_C(fragCoord.y, 1.0, 0.0, 0.0, bars[bar]);
|
|
||||||
|
|
||||||
// set color
|
|
||||||
fragColor.r=fg_color.x*x;
|
|
||||||
fragColor.g=fg_color.y*x;
|
|
||||||
fragColor.b=fg_color.z*x;
|
|
||||||
fragColor.a=1.0;
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
#version 330
|
|
||||||
|
|
||||||
in vec2 fragCoord;
|
|
||||||
out vec4 fragColor;
|
|
||||||
|
|
||||||
// bar values. defaults to left channels first (low to high), then right (high to low).
|
|
||||||
uniform float bars[512];
|
|
||||||
|
|
||||||
uniform int bars_count; // number of bars (left + right) (configurable)
|
|
||||||
|
|
||||||
uniform vec3 u_resolution; // window resolution, not used here
|
|
||||||
|
|
||||||
//colors, configurable in cava config file
|
|
||||||
uniform vec3 bg_color; // background color(r,g,b) (0.0 - 1.0), not used here
|
|
||||||
uniform vec3 fg_color; // foreground color, not used here
|
|
||||||
|
|
||||||
void main()
|
|
||||||
{
|
|
||||||
// find which bar to use based on where we are on the x axis
|
|
||||||
int bar = int(bars_count * fragCoord.x);
|
|
||||||
|
|
||||||
float bar_y = 1.0 - abs((fragCoord.y - 0.5)) * 2.0;
|
|
||||||
float y = (bars[bar]) * bar_y;
|
|
||||||
|
|
||||||
float bar_x = (fragCoord.x - float(bar) / float(bars_count)) * bars_count;
|
|
||||||
float bar_r = 1.0 - abs((bar_x - 0.5)) * 2;
|
|
||||||
|
|
||||||
bar_r = bar_r * bar_r * 2;
|
|
||||||
|
|
||||||
// set color
|
|
||||||
fragColor.r = fg_color.x * y * bar_r;
|
|
||||||
fragColor.g = fg_color.y * y * bar_r;
|
|
||||||
fragColor.b = fg_color.z * y * bar_r;
|
|
||||||
}
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
#version 330
|
|
||||||
|
|
||||||
|
|
||||||
// Input vertex data, different for all executions of this shader.
|
|
||||||
layout(location = 0) in vec3 vertexPosition_modelspace;
|
|
||||||
|
|
||||||
// Output data ; will be interpolated for each fragment.
|
|
||||||
out vec2 fragCoord;
|
|
||||||
|
|
||||||
void main()
|
|
||||||
{
|
|
||||||
gl_Position = vec4(vertexPosition_modelspace,1);
|
|
||||||
fragCoord = (vertexPosition_modelspace.xy+vec2(1,1))/2.0;
|
|
||||||
}
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
{
|
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
lib.my.makeHomePackageConfig {
|
|
||||||
inherit config pkgs;
|
|
||||||
packageName = "cava";
|
|
||||||
packagePath = [ "cava" ];
|
|
||||||
optionPath = [
|
|
||||||
"cli"
|
|
||||||
"media"
|
|
||||||
"cava"
|
|
||||||
];
|
|
||||||
extraConfig = {
|
|
||||||
my.home.xdg.configFile."cava" = {
|
|
||||||
source = ./config;
|
|
||||||
recursive = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
@@ -2,6 +2,7 @@
|
|||||||
config,
|
config,
|
||||||
lib,
|
lib,
|
||||||
pkgs,
|
pkgs,
|
||||||
|
secrets,
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
lib.my.makeSwitch {
|
lib.my.makeSwitch {
|
||||||
@@ -14,12 +15,16 @@ lib.my.makeSwitch {
|
|||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my = {
|
my = {
|
||||||
home = {
|
hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
playerctl
|
playerctl
|
||||||
go-musicfox
|
go-musicfox
|
||||||
];
|
];
|
||||||
xdg.configFile."go-musicfox/go-musicfox.ini".source = ./go-musicfox.ini;
|
sops.secrets.go-musicfox = {
|
||||||
|
sopsFile = secrets."go-musicfox.ini";
|
||||||
|
format = "binary";
|
||||||
|
path = "${config.my.hm.xdg.configHome}/go-musicfox/go-musicfox.ini";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
cli.media.mpd.enable = true;
|
cli.media.mpd.enable = true;
|
||||||
@@ -1,97 +0,0 @@
|
|||||||
# 启动页配置
|
|
||||||
[startup]
|
|
||||||
# 是否显示启动页
|
|
||||||
show=false
|
|
||||||
# 启动页进度条是否有回弹效果
|
|
||||||
progressOutBounce=true
|
|
||||||
# 启动页时长
|
|
||||||
loadingSeconds=2
|
|
||||||
# 启动页欢迎语
|
|
||||||
welcome=musicfox
|
|
||||||
# 启动时自动签到
|
|
||||||
signin=false
|
|
||||||
|
|
||||||
# 进度条配置
|
|
||||||
[progress]
|
|
||||||
# 进度条已加载字符
|
|
||||||
fullChar=#
|
|
||||||
# 进度条未加载字符
|
|
||||||
emptyChar=
|
|
||||||
|
|
||||||
# 主页面配置
|
|
||||||
[main]
|
|
||||||
# 是否显示标题
|
|
||||||
showTitle=true
|
|
||||||
# 加载中提示
|
|
||||||
loadingText=[加载中...]
|
|
||||||
# 歌曲音质,可选项:standard, exhigh, lossless, hires, jyeffect(高清环绕声), sky(沉浸环绕声), jymaster(超清母带) 进行音质判断
|
|
||||||
songLevel=hires
|
|
||||||
# 主题颜色
|
|
||||||
# 随机
|
|
||||||
# primaryColor=random
|
|
||||||
# 经典网易云音乐红
|
|
||||||
#primaryColor="#ea403f"
|
|
||||||
primaryColor="#6186D9"
|
|
||||||
# 是否显示歌词
|
|
||||||
showLyric=true
|
|
||||||
# 歌词偏移 ms
|
|
||||||
lyricOffset=0
|
|
||||||
# 显示歌词翻译
|
|
||||||
showLyricTrans=true
|
|
||||||
# 是否显示通知信息
|
|
||||||
showNotify=false
|
|
||||||
# 开启pprof, --pprof时会开启
|
|
||||||
pprofPort=9876
|
|
||||||
# altScreen显示模式
|
|
||||||
altScreen=true
|
|
||||||
# 双列显示,开启务必使用等宽字体
|
|
||||||
doubleColumn=true
|
|
||||||
# 下载目录,默认为$HOME/.go-musicfox/download
|
|
||||||
downloadDir=/home/imxyy/Music/go-musicfox
|
|
||||||
# 缓存目录,默认为${MUSICFOX_ROOT}/cache
|
|
||||||
cacheDir=/home/imxyy/Music/go-musicfox/.cache
|
|
||||||
# 缓存大小(以MB为单位),0为不使用缓存,-1为不限制,默认为0
|
|
||||||
cacheLimit=-1
|
|
||||||
# 是否显示歌单下所有歌曲,默认不开启,仅获取歌单前1000首,开启后可能会占用更多内存(大量歌曲数据)和带宽(会同时发送多个请求获取歌单下歌曲数据)
|
|
||||||
showAllSongsOfPlaylist=false
|
|
||||||
# 动态显示menu行数
|
|
||||||
dynamicMenuRows=true
|
|
||||||
enableMouseEvent = false
|
|
||||||
|
|
||||||
[autoplay]
|
|
||||||
# 是否开启自动播放,默认不开启
|
|
||||||
autoPlay=true
|
|
||||||
# 自动播放歌单,dailyReco,like,no(保持上次退出时的设置,无视offset),name:歌单名,默认dailyReco
|
|
||||||
autoPlayList="no"
|
|
||||||
# 播放偏移,0为第一首,-1为最后一首,默认为0
|
|
||||||
offset=0
|
|
||||||
# 播放模式,listLoop, order, singleLoop, random, intelligent(心动), last(上次退出时的模式),default,默认为last
|
|
||||||
playMode=singleLoop
|
|
||||||
|
|
||||||
[player]
|
|
||||||
# 播放引擎 beep / mpd(需要安装配置mpd) / osx(Mac才可用)
|
|
||||||
# 不填Mac默认使用osx,其他系统默认使用beep(推荐的配置)
|
|
||||||
engine=mpd
|
|
||||||
# beep使用的mp3解码器,可选:go-mp3, minimp3 (minimp3更少的CPU占用,但是稳定性不如go-mp3)
|
|
||||||
#beepMp3Decoder=go-mp3
|
|
||||||
|
|
||||||
# mpd配置
|
|
||||||
mpdBin=mpd
|
|
||||||
# !!!注意!!! 一定要在配置文件中设置pid_file,否则在退出时不会kill掉mpd进程
|
|
||||||
mpdConfigFile=/home/imxyy/.config/mpd/mpd.conf
|
|
||||||
mpdNetwork=tcp
|
|
||||||
mpdAddr=127.0.0.1:6600
|
|
||||||
|
|
||||||
[unm]
|
|
||||||
# UNM开关
|
|
||||||
switch=true
|
|
||||||
# UNM源: kuwo,kugou,migu,qq
|
|
||||||
sources=kuwo,kugou
|
|
||||||
# UNM搜索其他平台限制 0-3
|
|
||||||
searchLimit=0
|
|
||||||
# 解除会员限制
|
|
||||||
enableLocalVip=true
|
|
||||||
# 解除音质限制
|
|
||||||
unlockSoundEffects=true
|
|
||||||
# QQ音乐cookie文件
|
|
||||||
qqCookieFile=
|
|
||||||
@@ -13,7 +13,7 @@ lib.my.makeSwitch {
|
|||||||
"mpd"
|
"mpd"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs.stable; [
|
home.packages = with pkgs.stable; [
|
||||||
mpd
|
mpd
|
||||||
mpc-cli
|
mpc-cli
|
||||||
|
|||||||
@@ -23,8 +23,3 @@ audio_output {
|
|||||||
type "pipewire"
|
type "pipewire"
|
||||||
name "pipewire"
|
name "pipewire"
|
||||||
}
|
}
|
||||||
|
|
||||||
audio_output {
|
|
||||||
type "pulse"
|
|
||||||
name "pulseaudio"
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -42,11 +42,13 @@ lib.my.makeSwitch {
|
|||||||
dnsutils
|
dnsutils
|
||||||
|
|
||||||
killall
|
killall
|
||||||
|
|
||||||
|
comma
|
||||||
];
|
];
|
||||||
|
|
||||||
programs.dconf.enable = true;
|
programs.dconf.enable = true;
|
||||||
|
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
lsd
|
lsd
|
||||||
fd
|
fd
|
||||||
@@ -80,6 +82,10 @@ lib.my.makeSwitch {
|
|||||||
enableAutoUpdates = true;
|
enableAutoUpdates = true;
|
||||||
settings.updates.auto_update = true;
|
settings.updates.auto_update = true;
|
||||||
};
|
};
|
||||||
|
programs.television = {
|
||||||
|
enable = true;
|
||||||
|
enableZshIntegration = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ lib.my.makeHomePackageConfig {
|
|||||||
"btop"
|
"btop"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home.xdg.configFile."btop" = {
|
my.hm.xdg.configFile."btop" = {
|
||||||
source = ./config;
|
source = ./config;
|
||||||
recursive = true;
|
recursive = true;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -15,9 +15,9 @@ lib.my.makeSwitch {
|
|||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.persist.homeDirs = [ ".local/share/zoxide" ];
|
my.persist.homeDirs = [ ".local/share/zoxide" ];
|
||||||
my.home =
|
my.hm =
|
||||||
let
|
let
|
||||||
stateHome = config.my.home.xdg.stateHome;
|
stateHome = config.my.hm.xdg.stateHome;
|
||||||
zsh-syntax-highlighting = pkgs.fetchFromGitHub {
|
zsh-syntax-highlighting = pkgs.fetchFromGitHub {
|
||||||
owner = "zsh-users";
|
owner = "zsh-users";
|
||||||
repo = "zsh-syntax-highlighting";
|
repo = "zsh-syntax-highlighting";
|
||||||
@@ -44,11 +44,11 @@ lib.my.makeSwitch {
|
|||||||
jj = {
|
jj = {
|
||||||
ignore_timeout = true;
|
ignore_timeout = true;
|
||||||
description = "The current jj status";
|
description = "The current jj status";
|
||||||
when = "jj root";
|
when = true;
|
||||||
symbol = " ";
|
|
||||||
command = ''
|
command = ''
|
||||||
jj log --revisions @ --no-graph --ignore-working-copy --color always --limit 1 --template '
|
jj log --revisions @ --no-graph --ignore-working-copy --color always --limit 1 --template '
|
||||||
separate(" ",
|
separate(" ",
|
||||||
|
" ",
|
||||||
change_id.shortest(4),
|
change_id.shortest(4),
|
||||||
bookmarks,
|
bookmarks,
|
||||||
"|",
|
"|",
|
||||||
@@ -64,19 +64,9 @@ lib.my.makeSwitch {
|
|||||||
"(no description set)",
|
"(no description set)",
|
||||||
) ++ raw_escape_sequence("\x1b[0m"),
|
) ++ raw_escape_sequence("\x1b[0m"),
|
||||||
)
|
)
|
||||||
'
|
' || (starship module git_branch && starship module git_status)
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
git_branch = {
|
|
||||||
when = true;
|
|
||||||
command = "jj root >/dev/null 2>&1 || starship module git_branch";
|
|
||||||
description = "Only show git_branch if we're not in a jj repo";
|
|
||||||
};
|
|
||||||
git_status = {
|
|
||||||
when = true;
|
|
||||||
command = "jj root >/dev/null 2>&1 || starship module git_status";
|
|
||||||
description = "Only show git_status if we're not in a jj repo";
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
git_state.disabled = true;
|
git_state.disabled = true;
|
||||||
git_commit.disabled = true;
|
git_commit.disabled = true;
|
||||||
@@ -88,7 +78,7 @@ lib.my.makeSwitch {
|
|||||||
};
|
};
|
||||||
programs.zsh = {
|
programs.zsh = {
|
||||||
enable = true;
|
enable = true;
|
||||||
dotDir = ".config/zsh";
|
dotDir = "${config.my.hm.xdg.configHome}/zsh";
|
||||||
history = {
|
history = {
|
||||||
path = "${stateHome}/zsh_history";
|
path = "${stateHome}/zsh_history";
|
||||||
ignorePatterns = [
|
ignorePatterns = [
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
"git"
|
"git"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
programs.git = {
|
programs.git = {
|
||||||
userName = "${userfullname}";
|
userName = "${userfullname}";
|
||||||
userEmail = "${useremail}";
|
userEmail = "${useremail}";
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
"jj"
|
"jj"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
programs.jujutsu = {
|
programs.jujutsu = {
|
||||||
settings = {
|
settings = {
|
||||||
user = {
|
user = {
|
||||||
@@ -26,6 +26,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
ui = {
|
ui = {
|
||||||
graph.style = "square";
|
graph.style = "square";
|
||||||
default-command = "status";
|
default-command = "status";
|
||||||
|
conflict-marker-style = "snapshot";
|
||||||
};
|
};
|
||||||
signing = {
|
signing = {
|
||||||
backend = "ssh";
|
backend = "ssh";
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
"neovim"
|
"neovim"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
xdg.configFile."nvim/init.lua".source = ./nvim/init.lua;
|
xdg.configFile."nvim/init.lua".source = ./nvim/init.lua;
|
||||||
xdg.configFile."nvim/lua" = {
|
xdg.configFile."nvim/lua" = {
|
||||||
source = ./nvim/lua;
|
source = ./nvim/lua;
|
||||||
@@ -26,31 +26,9 @@ lib.my.makeHomeProgramConfig {
|
|||||||
vimAlias = true;
|
vimAlias = true;
|
||||||
vimdiffAlias = true;
|
vimdiffAlias = true;
|
||||||
extraPackages = with pkgs; [
|
extraPackages = with pkgs; [
|
||||||
gcc
|
gcc # treesitter
|
||||||
gnumake
|
|
||||||
|
|
||||||
pyright
|
ripgrep # telescope
|
||||||
|
|
||||||
clang-tools
|
|
||||||
|
|
||||||
rust-analyzer
|
|
||||||
pest-ide-tools
|
|
||||||
|
|
||||||
nixd
|
|
||||||
|
|
||||||
gotools
|
|
||||||
gopls
|
|
||||||
|
|
||||||
stylua
|
|
||||||
lua-language-server
|
|
||||||
|
|
||||||
nodePackages.vscode-langservers-extracted
|
|
||||||
nodePackages.typescript-language-server
|
|
||||||
vue-language-server
|
|
||||||
typescript
|
|
||||||
nodejs
|
|
||||||
|
|
||||||
ripgrep
|
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -4,5 +4,3 @@ require("core.keymaps")
|
|||||||
require("langs.langs-setup")
|
require("langs.langs-setup")
|
||||||
|
|
||||||
require("plugins.plugins-setup")
|
require("plugins.plugins-setup")
|
||||||
|
|
||||||
require("core.autostart")
|
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
-- Open tree when in config dir
|
|
||||||
local configdir = vim.fn.system("echo $HOME/.config")
|
|
||||||
configdir = string.sub(configdir, 1, string.len(configdir) - 1)
|
|
||||||
if string.find(vim.fn.system("pwd"), configdir) ~= nil then
|
|
||||||
vim.cmd("NvimTreeOpen")
|
|
||||||
vim.cmd("NvimTmuxNavigateRight")
|
|
||||||
end
|
|
||||||
@@ -7,33 +7,21 @@ local buf_kill = globals.buf_kill
|
|||||||
|
|
||||||
keymap.set("v", "<S-pageup>", ":m '<-2<CR>gv=gv", opt)
|
keymap.set("v", "<S-pageup>", ":m '<-2<CR>gv=gv", opt)
|
||||||
keymap.set("v", "<S-pagedown>", ":m '>+1<CR>gv=gv", opt)
|
keymap.set("v", "<S-pagedown>", ":m '>+1<CR>gv=gv", opt)
|
||||||
|
keymap.set({ "i", "n", "v" }, "<S-up>", "<up>", opt)
|
||||||
|
keymap.set({ "i", "n", "v" }, "<S-down>", "<down>", opt)
|
||||||
|
|
||||||
keymap.set("n", "<leader>nh", ":nohl<CR>", opt)
|
keymap.set("n", "<leader>nh", ":nohl<CR>", opt)
|
||||||
|
|
||||||
keymap.set("n", "<leader>sv", "<C-w>v", opt)
|
keymap.set("n", "<leader>sv", "<C-w>v", opt)
|
||||||
keymap.set("n", "<leader>sh", "<C-w>s", opt)
|
keymap.set("n", "<leader>sh", "<C-w>s", opt)
|
||||||
|
|
||||||
keymap.set("i", "<S-up>", "<ESC>v<up>", opt)
|
|
||||||
keymap.set("i", "<S-down>", "<ESC>v<down>", opt)
|
|
||||||
keymap.set("n", "<S-up>", "v<up>", opt)
|
|
||||||
keymap.set("n", "<S-down>", "v<down>", opt)
|
|
||||||
keymap.set("v", "<S-up>", "<up>", opt)
|
|
||||||
keymap.set("v", "<S-down>", "<down>", opt)
|
|
||||||
|
|
||||||
keymap.set("i", "<S-left>", "<ESC>v<left>", opt)
|
|
||||||
keymap.set("i", "<S-right>", "<ESC>v<right>", opt)
|
|
||||||
keymap.set("n", "<S-left>", "v<left>", opt)
|
|
||||||
keymap.set("n", "<S-right>", "v<right>", opt)
|
|
||||||
keymap.set("v", "<S-left>", "<left>", opt)
|
|
||||||
keymap.set("v", "<S-right>", "<right>", opt)
|
|
||||||
|
|
||||||
keymap.set("v", ".", ">gv", opt)
|
keymap.set("v", ".", ">gv", opt)
|
||||||
keymap.set("v", ",", "<gv", opt)
|
keymap.set("v", ",", "<gv", opt)
|
||||||
|
|
||||||
keymap.set({ "n", "v" }, "<pageup>", "9k", opt)
|
keymap.set({ "n", "v" }, "<pageup>", "9k", opt)
|
||||||
keymap.set({ "n", "v" }, "<pagedown>", "9j", opt)
|
keymap.set({ "n", "v" }, "<pagedown>", "9j", opt)
|
||||||
keymap.set("i", "<pageup>", "<up><up><up><up><up><up><up><up><up>", opt)
|
keymap.set("i", "<pageup>", string.rep("<up>", 9), opt)
|
||||||
keymap.set("i", "<pagedown>", "<down><down><down><down><down><down><down><down><down>", opt)
|
keymap.set("i", "<pagedown>", string.rep("<down>", 9), opt)
|
||||||
|
|
||||||
keymap.set("n", "<leader>ww", ":w<CR>", opt)
|
keymap.set("n", "<leader>ww", ":w<CR>", opt)
|
||||||
keymap.set("n", "<leader>so", ":so<CR>", opt)
|
keymap.set("n", "<leader>so", ":so<CR>", opt)
|
||||||
@@ -54,15 +42,6 @@ keymap.set("n", "L", ":BufferLineCycleNext<CR>", opt)
|
|||||||
keymap.set("n", "<A-h>", ":BufferLineMovePrev<CR>", opt)
|
keymap.set("n", "<A-h>", ":BufferLineMovePrev<CR>", opt)
|
||||||
keymap.set("n", "<A-l>", ":BufferLineMoveNext<CR>", opt)
|
keymap.set("n", "<A-l>", ":BufferLineMoveNext<CR>", opt)
|
||||||
|
|
||||||
-- reload config
|
|
||||||
keymap.set("n", "<leader>rc", ":so ~/.config/nvim/init.lua<CR>", opt)
|
|
||||||
keymap.set("n", "<leader>rp", ":so ~/.config/nvim/lua/plugins/plugins-setup.lua<CR>", opt)
|
|
||||||
|
|
||||||
-- Workspaces
|
|
||||||
keymap.set("n", "<leader>wo", ":Telescope workspaces<CR>", opt)
|
|
||||||
keymap.set("n", "<leader>wa", ":WorkspacesAdd<CR>", opt)
|
|
||||||
keymap.set("n", "<leader>wr", ":WorkspacesRemove<CR>", opt)
|
|
||||||
|
|
||||||
-- Neovide config
|
-- Neovide config
|
||||||
if vim.g.neovide then
|
if vim.g.neovide then
|
||||||
keymap.set("v", "<C-C>", '"+y', opt)
|
keymap.set("v", "<C-C>", '"+y', opt)
|
||||||
|
|||||||
@@ -30,6 +30,8 @@ opt.timeoutlen = 500
|
|||||||
|
|
||||||
opt.completeopt = ""
|
opt.completeopt = ""
|
||||||
|
|
||||||
|
opt.exrc = true
|
||||||
|
|
||||||
opt.autoread = true
|
opt.autoread = true
|
||||||
vim.g.autoread = true
|
vim.g.autoread = true
|
||||||
|
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ local servers = {
|
|||||||
"cssls",
|
"cssls",
|
||||||
"nixd",
|
"nixd",
|
||||||
"html",
|
"html",
|
||||||
|
"java_language_server",
|
||||||
}
|
}
|
||||||
|
|
||||||
local extra_config = {
|
local extra_config = {
|
||||||
@@ -35,7 +36,7 @@ local extra_config = {
|
|||||||
},
|
},
|
||||||
rust_analyzer = {
|
rust_analyzer = {
|
||||||
settings = {
|
settings = {
|
||||||
rust_analyzer = {
|
["rust-analyzer"] = {
|
||||||
check = {
|
check = {
|
||||||
command = "clippy",
|
command = "clippy",
|
||||||
},
|
},
|
||||||
@@ -63,8 +64,8 @@ local extra_config = {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
qmlls = {
|
qmlls = {
|
||||||
cmd = {"qmlls", "-E"}
|
cmd = { "qmlls", "-E" },
|
||||||
}
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
local capabilities = require("cmp_nvim_lsp").default_capabilities()
|
local capabilities = require("cmp_nvim_lsp").default_capabilities()
|
||||||
@@ -73,7 +74,6 @@ capabilities.textDocument.foldingRange = {
|
|||||||
dynamicRegistration = false,
|
dynamicRegistration = false,
|
||||||
lineFoldingOnly = true,
|
lineFoldingOnly = true,
|
||||||
}
|
}
|
||||||
local lspconfig = require("lspconfig")
|
|
||||||
for _, server in ipairs(servers) do
|
for _, server in ipairs(servers) do
|
||||||
local extra = extra_config[server] or {}
|
local extra = extra_config[server] or {}
|
||||||
local config = {
|
local config = {
|
||||||
@@ -82,5 +82,6 @@ for _, server in ipairs(servers) do
|
|||||||
for k, v in pairs(extra) do
|
for k, v in pairs(extra) do
|
||||||
config[k] = v
|
config[k] = v
|
||||||
end
|
end
|
||||||
lspconfig[server].setup(config)
|
vim.lsp.config(server, config)
|
||||||
|
vim.lsp.enable(server)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
M = {
|
|
||||||
-- ensure_installed = require("plugins.lsp.servers")
|
|
||||||
ensure_installed = {},
|
|
||||||
}
|
|
||||||
|
|
||||||
return M
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
M = {
|
|
||||||
ui = {
|
|
||||||
icons = {
|
|
||||||
package_installed = "✓",
|
|
||||||
package_pending = "➜",
|
|
||||||
package_uninstalled = "✗",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
return M
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
M = {
|
|
||||||
"lua_ls",
|
|
||||||
"pyright",
|
|
||||||
"gopls",
|
|
||||||
"clangd",
|
|
||||||
"rust_analyzer",
|
|
||||||
"ts_ls",
|
|
||||||
"jsonls",
|
|
||||||
"cssls",
|
|
||||||
"nil_ls",
|
|
||||||
"html",
|
|
||||||
}
|
|
||||||
|
|
||||||
return M
|
|
||||||
@@ -17,4 +17,16 @@ local opt = require("core.globals").keymap_opt
|
|||||||
vim.keymap.set("n", "<leader>e", ":NvimTreeToggle<CR>", opt)
|
vim.keymap.set("n", "<leader>e", ":NvimTreeToggle<CR>", opt)
|
||||||
vim.keymap.set("n", "<leader>te", ":NvimTreeFocus<CR>", opt)
|
vim.keymap.set("n", "<leader>te", ":NvimTreeFocus<CR>", opt)
|
||||||
|
|
||||||
|
vim.api.nvim_create_autocmd("BufEnter", {
|
||||||
|
group = vim.api.nvim_create_augroup("NvimTreeCloseOnLast", { clear = true }),
|
||||||
|
pattern = "NvimTree*",
|
||||||
|
callback = function()
|
||||||
|
if vim.api.nvim_call_function("winlayout", {})[1] == "leaf" and vim.bo.filetype == "NvimTree" then
|
||||||
|
vim.defer_fn(function()
|
||||||
|
vim.cmd("NvimTreeClose")
|
||||||
|
end, 10)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
return M
|
return M
|
||||||
@@ -113,7 +113,7 @@ local plugins = {
|
|||||||
"MysticalDevil/inlay-hints.nvim",
|
"MysticalDevil/inlay-hints.nvim",
|
||||||
event = "LspAttach",
|
event = "LspAttach",
|
||||||
dependencies = { "neovim/nvim-lspconfig" },
|
dependencies = { "neovim/nvim-lspconfig" },
|
||||||
opts = {}
|
opts = {},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"hedyhli/outline.nvim",
|
"hedyhli/outline.nvim",
|
||||||
@@ -149,7 +149,7 @@ local plugins = {
|
|||||||
{
|
{
|
||||||
"numToStr/Comment.nvim",
|
"numToStr/Comment.nvim",
|
||||||
event = "VeryLazy",
|
event = "VeryLazy",
|
||||||
opts = {}
|
opts = {},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"windwp/nvim-autopairs",
|
"windwp/nvim-autopairs",
|
||||||
@@ -179,22 +179,42 @@ local plugins = {
|
|||||||
require("telescope").setup(require("plugins.telescope"))
|
require("telescope").setup(require("plugins.telescope"))
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"dnlhc/glance.nvim",
|
||||||
|
cmd = "Glance",
|
||||||
|
keys = {
|
||||||
|
{
|
||||||
|
"<leader>lr",
|
||||||
|
"<cmd>Glance references<cr>",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>ld",
|
||||||
|
"<cmd>Glance definitions<cr>",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>lD",
|
||||||
|
"<cmd>Glance type_definitions<cr>",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<leader>li",
|
||||||
|
"<cmd>Glance implementations<cr>",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"ggandor/leap.nvim",
|
"ggandor/leap.nvim",
|
||||||
dependencies = { "tpope/vim-repeat" },
|
dependencies = { "tpope/vim-repeat" },
|
||||||
config = function()
|
config = function()
|
||||||
require("leap").set_default_mappings()
|
vim.keymap.set({ "n", "x", "o" }, "s", "<Plug>(leap)")
|
||||||
|
vim.keymap.set("n", "S", "<Plug>(leap-from-window)")
|
||||||
-- Exclude whitespace and the middle of alphabetic words from preview:
|
-- Exclude whitespace and the middle of alphabetic words from preview:
|
||||||
-- foobar[baaz] = quux
|
-- foobar[baaz] = quux
|
||||||
-- ^----^^^--^^-^-^--^
|
-- ^----^^^--^^-^-^--^
|
||||||
require('leap').opts.preview_filter = function(ch0, ch1, ch2)
|
require("leap").opts.preview_filter = function(ch0, ch1, ch2)
|
||||||
return not (
|
return not (ch1:match("%s") or ch0:match("%a") and ch1:match("%a") and ch2:match("%a"))
|
||||||
ch1:match('%s') or
|
|
||||||
ch0:match('%a') and ch1:match('%a') and ch2:match('%a')
|
|
||||||
)
|
|
||||||
end
|
end
|
||||||
require('leap.user').set_repeat_keys('<enter>', '<backspace>')
|
require("leap.user").set_repeat_keys("<enter>", "<backspace>")
|
||||||
end
|
end,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"alexghergh/nvim-tmux-navigation",
|
"alexghergh/nvim-tmux-navigation",
|
||||||
|
|||||||
@@ -35,9 +35,6 @@ keymap.set("n", "<leader>gf", builtin.git_files, opt)
|
|||||||
keymap.set("n", "<leader>fg", builtin.live_grep, opt)
|
keymap.set("n", "<leader>fg", builtin.live_grep, opt)
|
||||||
keymap.set("n", "<leader>fb", builtin.buffers, opt)
|
keymap.set("n", "<leader>fb", builtin.buffers, opt)
|
||||||
keymap.set("n", "<leader>fh", builtin.help_tags, opt)
|
keymap.set("n", "<leader>fh", builtin.help_tags, opt)
|
||||||
-- keymap.set('n', '<leader>lD', builtin.diagnostics, opt)
|
|
||||||
keymap.set("n", "<leader>ld", builtin.lsp_definitions, opt)
|
|
||||||
keymap.set("n", "<leader>lr", builtin.lsp_references, opt)
|
|
||||||
keymap.set("n", "<leader>ls", builtin.lsp_document_symbols, opt)
|
keymap.set("n", "<leader>ls", builtin.lsp_document_symbols, opt)
|
||||||
keymap.set("n", "<leader>/", builtin.current_buffer_fuzzy_find, opt)
|
keymap.set("n", "<leader>/", builtin.current_buffer_fuzzy_find, opt)
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
"vscode"
|
"vscode"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
programs.vscode = {
|
programs.vscode = {
|
||||||
package = pkgs.vscodium;
|
package = pkgs.vscodium;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ lib.my.makeSwitch {
|
|||||||
python.enable = true;
|
python.enable = true;
|
||||||
rust.enable = true;
|
rust.enable = true;
|
||||||
lua.enable = true;
|
lua.enable = true;
|
||||||
|
java.enable = true;
|
||||||
qml.enable = true;
|
qml.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lib.my.makeSwitch {
|
|||||||
"c"
|
"c"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home.home.packages = with pkgs; [
|
my.hm.home.packages = with pkgs; [
|
||||||
gcc
|
gcc
|
||||||
clang-tools
|
clang-tools
|
||||||
cmake
|
cmake
|
||||||
|
|||||||
@@ -14,6 +14,10 @@ lib.my.makeHomePackageConfig {
|
|||||||
"go"
|
"go"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
|
my.hm.home.packages = with pkgs; [
|
||||||
|
gotools
|
||||||
|
gopls
|
||||||
|
];
|
||||||
my.persist.homeDirs = [
|
my.persist.homeDirs = [
|
||||||
"go"
|
"go"
|
||||||
];
|
];
|
||||||
|
|||||||
21
modules/coding/langs/java.nix
Normal file
21
modules/coding/langs/java.nix
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
lib.my.makeSwitch {
|
||||||
|
inherit config;
|
||||||
|
optionName = "java";
|
||||||
|
optionPath = [
|
||||||
|
"coding"
|
||||||
|
"langs"
|
||||||
|
"java"
|
||||||
|
];
|
||||||
|
config' = {
|
||||||
|
my.hm.home.packages = with pkgs; [
|
||||||
|
openjdk24
|
||||||
|
java-language-server
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -13,12 +13,13 @@ lib.my.makeSwitch {
|
|||||||
"js"
|
"js"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
nodejs
|
nodejs
|
||||||
nodePackages.npm
|
|
||||||
|
|
||||||
typescript
|
typescript
|
||||||
|
|
||||||
|
nodePackages.typescript-language-server
|
||||||
|
vue-language-server
|
||||||
];
|
];
|
||||||
home.file.".npmrc".text = ''
|
home.file.".npmrc".text = ''
|
||||||
prefix = ''${HOME}/.npm-global
|
prefix = ''${HOME}/.npm-global
|
||||||
|
|||||||
@@ -13,8 +13,10 @@ lib.my.makeSwitch {
|
|||||||
"lua"
|
"lua"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home.home.packages = with pkgs; [
|
my.hm.home.packages = with pkgs; [
|
||||||
luajit
|
luajit
|
||||||
|
stylua
|
||||||
|
lua-language-server
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,8 +14,9 @@ lib.my.makeHomePackageConfig {
|
|||||||
"python"
|
"python"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home.home.packages = with pkgs; [
|
my.hm.home.packages = with pkgs; [
|
||||||
uv
|
uv
|
||||||
|
pyright
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lib.my.makeSwitch {
|
|||||||
"qml"
|
"qml"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home.home.packages = with pkgs; [
|
my.hm.home.packages = with pkgs; [
|
||||||
kdePackages.qtdeclarative
|
kdePackages.qtdeclarative
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lib.my.makeSwitch {
|
|||||||
"rust"
|
"rust"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
(fenix.stable.withComponents [
|
(fenix.stable.withComponents [
|
||||||
"cargo"
|
"cargo"
|
||||||
@@ -21,8 +21,11 @@ lib.my.makeSwitch {
|
|||||||
"rust-src"
|
"rust-src"
|
||||||
"rustc"
|
"rustc"
|
||||||
"rustfmt"
|
"rustfmt"
|
||||||
|
"rust-analyzer"
|
||||||
])
|
])
|
||||||
evcxr # rust repl
|
evcxr # rust repl
|
||||||
|
|
||||||
|
pest-ide-tools
|
||||||
];
|
];
|
||||||
home.file.".cargo/config.toml".text = ''
|
home.file.".cargo/config.toml".text = ''
|
||||||
[source.crates-io]
|
[source.crates-io]
|
||||||
@@ -34,6 +37,9 @@ lib.my.makeSwitch {
|
|||||||
[net]
|
[net]
|
||||||
git-fetch-with-cli = true
|
git-fetch-with-cli = true
|
||||||
'';
|
'';
|
||||||
|
programs.zsh.initContent = lib.mkAfter ''
|
||||||
|
export PATH=$PATH:$HOME/.cargo/bin
|
||||||
|
'';
|
||||||
};
|
};
|
||||||
my.persist.homeDirs = [
|
my.persist.homeDirs = [
|
||||||
".cargo"
|
".cargo"
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ lib.my.makeSwitch {
|
|||||||
"misc"
|
"misc"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
gnumake
|
gnumake
|
||||||
github-cli # gh
|
github-cli # gh
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ lib.my.makeSwitch {
|
|||||||
terminal.all.enable = true;
|
terminal.all.enable = true;
|
||||||
wm.all.enable = true;
|
wm.all.enable = true;
|
||||||
style.enable = true;
|
style.enable = true;
|
||||||
quickshell.enable = true;
|
|
||||||
wine.enable = true;
|
wine.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ lib.my.makeSwitch {
|
|||||||
config' = {
|
config' = {
|
||||||
my.desktop.browser = {
|
my.desktop.browser = {
|
||||||
firefox.enable = true;
|
firefox.enable = true;
|
||||||
librewolf.enable = true;
|
|
||||||
chromium.enable = true;
|
chromium.enable = true;
|
||||||
zen.enable = true;
|
zen.enable = true;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
"chromium"
|
"chromium"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home.programs.chromium = {
|
my.hm.programs.chromium = {
|
||||||
package = pkgs.ungoogled-chromium;
|
package = pkgs.ungoogled-chromium;
|
||||||
extensions = [
|
extensions = [
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -1,15 +0,0 @@
|
|||||||
{ config, lib, ... }:
|
|
||||||
lib.my.makeHomeProgramConfig {
|
|
||||||
inherit config;
|
|
||||||
programName = "librewolf";
|
|
||||||
optionPath = [
|
|
||||||
"desktop"
|
|
||||||
"browser"
|
|
||||||
"librewolf"
|
|
||||||
];
|
|
||||||
extraConfig = {
|
|
||||||
my.persist.homeDirs = [
|
|
||||||
".librewolf"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
}
|
|
||||||
@@ -13,7 +13,7 @@ lib.my.makeHomeProgramConfig {
|
|||||||
"zen"
|
"zen"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home.programs.zen-browser = {
|
my.hm.programs.zen-browser = {
|
||||||
enable = true;
|
enable = true;
|
||||||
nativeMessagingHosts = [ pkgs.firefoxpwa ];
|
nativeMessagingHosts = [ pkgs.firefoxpwa ];
|
||||||
policies = {
|
policies = {
|
||||||
|
|||||||
@@ -13,18 +13,17 @@ lib.my.makeSwitch {
|
|||||||
"minecraft"
|
"minecraft"
|
||||||
];
|
];
|
||||||
config' = {
|
config' = {
|
||||||
my.home.home.packages = with pkgs; [
|
my.hm.home.packages = [
|
||||||
hmcl
|
(pkgs.hmcl.overrideAttrs {
|
||||||
|
postFixup = ''
|
||||||
openjdk21
|
substituteInPlace $out/share/applications/HMCL.desktop --replace-fail 'Exec=hmcl' 'Exec=sh -c "cd ~/.local/share/hmcl; hmcl"'
|
||||||
|
'';
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
|
||||||
my.persist.homeDirs = [
|
my.persist.homeDirs = [
|
||||||
".minecraft"
|
".minecraft"
|
||||||
".local/share/hmcl"
|
".local/share/hmcl"
|
||||||
];
|
];
|
||||||
my.persist.homeFiles = [
|
|
||||||
".hmcl.json"
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,6 +14,6 @@ lib.my.makeHomePackageConfig {
|
|||||||
"dunst"
|
"dunst"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home.xdg.configFile."dunst/dunstrc".source = ./dunstrc;
|
my.hm.xdg.configFile."dunst/dunstrc".source = ./dunstrc;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ lib.my.makeHomePackageConfig {
|
|||||||
"swaync"
|
"swaync"
|
||||||
];
|
];
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
my.home = {
|
my.hm = {
|
||||||
programs.niri.settings.binds."Mod+End".action.spawn = [
|
programs.niri.settings.binds."Mod+End".action.spawn = [
|
||||||
"swaync-client"
|
"swaync-client"
|
||||||
"-t"
|
"-t"
|
||||||
|
|||||||
@@ -1,43 +0,0 @@
|
|||||||
{
|
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
|
||||||
# FIXME: symlink
|
|
||||||
homeDir = config.my.home.home.homeDirectory;
|
|
||||||
quickshellDir = "${homeDir}/workspace/nixos-dotfiles/modules/desktop/quickshell/qml";
|
|
||||||
quickshellTarget = "${homeDir}/.config/quickshell";
|
|
||||||
in
|
|
||||||
lib.my.makeSwitch {
|
|
||||||
inherit config;
|
|
||||||
default = false;
|
|
||||||
optionName = "quickshell";
|
|
||||||
optionPath = [
|
|
||||||
"desktop"
|
|
||||||
"quickshell"
|
|
||||||
];
|
|
||||||
config' = {
|
|
||||||
my.home.home = {
|
|
||||||
packages = with pkgs; [
|
|
||||||
quickshell
|
|
||||||
qt6Packages.qt5compat
|
|
||||||
libsForQt5.qt5.qtgraphicaleffects
|
|
||||||
kdePackages.qtbase
|
|
||||||
kdePackages.qtdeclarative
|
|
||||||
|
|
||||||
material-symbols
|
|
||||||
material-icons
|
|
||||||
];
|
|
||||||
sessionVariables.QML2_IMPORT_PATH = lib.concatStringsSep ":" [
|
|
||||||
"${pkgs.quickshell}/lib/qt-6/qml"
|
|
||||||
"${pkgs.kdePackages.qtdeclarative}/lib/qt-6/qml"
|
|
||||||
"${pkgs.kdePackages.kirigami.unwrapped}/lib/qt-6/qml"
|
|
||||||
];
|
|
||||||
activation.symlinkQuickshellAndFaceIcon = lib.hm.dag.entryAfter [ "writeBoundary" ] ''
|
|
||||||
ln -sfn "${quickshellDir}" "${quickshellTarget}"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
2
modules/desktop/quickshell/qml/.gitignore
vendored
2
modules/desktop/quickshell/qml/.gitignore
vendored
@@ -1,2 +0,0 @@
|
|||||||
/debug.log
|
|
||||||
/quickshell.log
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 37 KiB |
@@ -1,84 +0,0 @@
|
|||||||
import QtQuick
|
|
||||||
import QtQuick.Shapes
|
|
||||||
import "root:/Data" as Settings
|
|
||||||
|
|
||||||
// Concave corner shape component for rounded panel edges
|
|
||||||
Shape {
|
|
||||||
id: root
|
|
||||||
|
|
||||||
property string position: "topleft" // Corner position: topleft/topright/bottomleft/bottomright
|
|
||||||
property real size: 1.0 // Scale multiplier for entire corner
|
|
||||||
property int concaveWidth: 100 * size
|
|
||||||
property int concaveHeight: 60 * size
|
|
||||||
property int offsetX: -20
|
|
||||||
property int offsetY: -20
|
|
||||||
property color fillColor: Settings.Colors.bgColor
|
|
||||||
property int arcRadius: 20 * size
|
|
||||||
|
|
||||||
// Position flags derived from position string
|
|
||||||
property bool _isTop: position.includes("top")
|
|
||||||
property bool _isLeft: position.includes("left")
|
|
||||||
property bool _isRight: position.includes("right")
|
|
||||||
property bool _isBottom: position.includes("bottom")
|
|
||||||
|
|
||||||
// Base coordinates for left corner shape
|
|
||||||
property real _baseStartX: 30 * size
|
|
||||||
property real _baseStartY: _isTop ? 20 * size : 0
|
|
||||||
property real _baseLineX: 30 * size
|
|
||||||
property real _baseLineY: _isTop ? 0 : 20 * size
|
|
||||||
property real _baseArcX: 50 * size
|
|
||||||
property real _baseArcY: _isTop ? 20 * size : 0
|
|
||||||
|
|
||||||
// Mirror coordinates for right corners
|
|
||||||
property real _startX: _isRight ? (concaveWidth - _baseStartX) : _baseStartX
|
|
||||||
property real _startY: _baseStartY
|
|
||||||
property real _lineX: _isRight ? (concaveWidth - _baseLineX) : _baseLineX
|
|
||||||
property real _lineY: _baseLineY
|
|
||||||
property real _arcX: _isRight ? (concaveWidth - _baseArcX) : _baseArcX
|
|
||||||
property real _arcY: _baseArcY
|
|
||||||
|
|
||||||
// Arc direction varies by corner to maintain proper concave shape
|
|
||||||
property int _arcDirection: {
|
|
||||||
if (_isTop && _isLeft)
|
|
||||||
return PathArc.Counterclockwise;
|
|
||||||
if (_isTop && _isRight)
|
|
||||||
return PathArc.Clockwise;
|
|
||||||
if (_isBottom && _isLeft)
|
|
||||||
return PathArc.Clockwise;
|
|
||||||
if (_isBottom && _isRight)
|
|
||||||
return PathArc.Counterclockwise;
|
|
||||||
return PathArc.Counterclockwise;
|
|
||||||
}
|
|
||||||
|
|
||||||
width: concaveWidth
|
|
||||||
height: concaveHeight
|
|
||||||
// Position relative to parent based on corner type
|
|
||||||
x: _isLeft ? offsetX : (parent ? parent.width - width + offsetX : 0)
|
|
||||||
y: _isTop ? offsetY : (parent ? parent.height - height + offsetY : 0)
|
|
||||||
preferredRendererType: Shape.CurveRenderer
|
|
||||||
layer.enabled: true
|
|
||||||
layer.samples: 4
|
|
||||||
|
|
||||||
ShapePath {
|
|
||||||
strokeWidth: 0
|
|
||||||
fillColor: root.fillColor
|
|
||||||
strokeColor: root.fillColor // Use same color as fill to eliminate artifacts
|
|
||||||
|
|
||||||
startX: root._startX
|
|
||||||
startY: root._startY
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: root._lineX
|
|
||||||
y: root._lineY
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: root._arcX
|
|
||||||
y: root._arcY
|
|
||||||
radiusX: root.arcRadius
|
|
||||||
radiusY: root.arcRadius
|
|
||||||
useLargeArc: false
|
|
||||||
direction: root._arcDirection
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,48 +0,0 @@
|
|||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
id: root
|
|
||||||
|
|
||||||
// Keep track of loaded components
|
|
||||||
property var activeLoaders: ({})
|
|
||||||
|
|
||||||
// Dynamically load a QML component
|
|
||||||
function load(componentUrl, parent, properties) {
|
|
||||||
if (!activeLoaders[componentUrl]) {
|
|
||||||
var loader = Qt.createQmlObject(`
|
|
||||||
import QtQuick
|
|
||||||
Loader {
|
|
||||||
active: false
|
|
||||||
asynchronous: true
|
|
||||||
visible: false
|
|
||||||
}
|
|
||||||
`, parent);
|
|
||||||
|
|
||||||
loader.source = componentUrl;
|
|
||||||
loader.active = true;
|
|
||||||
|
|
||||||
if (properties) {
|
|
||||||
for (var prop in properties) {
|
|
||||||
loader[prop] = properties[prop];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
activeLoaders[componentUrl] = loader;
|
|
||||||
}
|
|
||||||
return activeLoaders[componentUrl];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Destroy and remove a loaded component
|
|
||||||
function unload(componentUrl) {
|
|
||||||
if (activeLoaders[componentUrl]) {
|
|
||||||
activeLoaders[componentUrl].active = false;
|
|
||||||
activeLoaders[componentUrl].destroy();
|
|
||||||
delete activeLoaders[componentUrl];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if a component is loaded
|
|
||||||
function isLoaded(componentUrl) {
|
|
||||||
return !!activeLoaders[componentUrl];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,189 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
import Quickshell.Io
|
|
||||||
|
|
||||||
// System process and resource monitoring
|
|
||||||
QtObject {
|
|
||||||
id: root
|
|
||||||
|
|
||||||
// System resource metrics
|
|
||||||
property real cpuUsage: 0
|
|
||||||
property real ramUsage: 0
|
|
||||||
property real totalRam: 0
|
|
||||||
property real usedRam: 0
|
|
||||||
|
|
||||||
// System control processes
|
|
||||||
property Process shutdownProcess: Process {
|
|
||||||
command: ["shutdown", "-h", "now"]
|
|
||||||
}
|
|
||||||
|
|
||||||
property Process rebootProcess: Process {
|
|
||||||
command: ["reboot"]
|
|
||||||
}
|
|
||||||
|
|
||||||
property Process lockProcess: Process {
|
|
||||||
command: ["hyprlock"]
|
|
||||||
}
|
|
||||||
|
|
||||||
property Process logoutProcess: Process {
|
|
||||||
command: ["loginctl", "terminate-user", "$USER"]
|
|
||||||
}
|
|
||||||
|
|
||||||
property Process pavucontrolProcess: Process {
|
|
||||||
command: ["pavucontrol"]
|
|
||||||
}
|
|
||||||
|
|
||||||
// Resource monitoring processes
|
|
||||||
property Process cpuProcess: Process {
|
|
||||||
command: ["sh", "-c", "grep '^cpu ' /proc/stat | awk '{usage=($2+$3+$4)*100/($2+$3+$4+$5)} END {print usage}'"]
|
|
||||||
stdout: SplitParser {
|
|
||||||
onRead: data => {
|
|
||||||
root.cpuUsage = parseFloat(data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
property Process ramProcess: Process {
|
|
||||||
command: ["sh", "-c", "free -b | awk '/Mem:/ {print $2\" \"$3\" \"$3/$2*100}'"]
|
|
||||||
stdout: SplitParser {
|
|
||||||
onRead: data => {
|
|
||||||
var parts = data.trim().split(/\s+/);
|
|
||||||
if (parts.length >= 3) {
|
|
||||||
root.totalRam = parseFloat(parts[0]) / (1024 * 1024 * 1024);
|
|
||||||
root.usedRam = parseFloat(parts[1]) / (1024 * 1024 * 1024);
|
|
||||||
root.ramUsage = parseFloat(parts[2]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Monitoring timers (start manually when needed)
|
|
||||||
property Timer cpuTimer: Timer {
|
|
||||||
interval: 30000
|
|
||||||
running: false
|
|
||||||
repeat: true
|
|
||||||
onTriggered: {
|
|
||||||
cpuProcess.running = false;
|
|
||||||
cpuProcess.running = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
property Timer ramTimer: Timer {
|
|
||||||
interval: 30000
|
|
||||||
running: false
|
|
||||||
repeat: true
|
|
||||||
onTriggered: {
|
|
||||||
ramProcess.running = false;
|
|
||||||
ramProcess.running = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// System control functions
|
|
||||||
function shutdown() {
|
|
||||||
console.log("Executing shutdown command");
|
|
||||||
shutdownProcess.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function reboot() {
|
|
||||||
console.log("Executing reboot command");
|
|
||||||
rebootProcess.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function lock() {
|
|
||||||
console.log("Executing lock command");
|
|
||||||
lockProcess.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function logout() {
|
|
||||||
console.log("Executing logout command");
|
|
||||||
logoutProcess.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function openPavuControl() {
|
|
||||||
console.log("Opening PavuControl");
|
|
||||||
pavucontrolProcess.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Performance monitoring control
|
|
||||||
function startMonitoring() {
|
|
||||||
console.log("Starting system monitoring");
|
|
||||||
cpuTimer.running = true;
|
|
||||||
ramTimer.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function stopMonitoring() {
|
|
||||||
console.log("Stopping system monitoring");
|
|
||||||
cpuTimer.running = false;
|
|
||||||
ramTimer.running = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function setMonitoringInterval(intervalMs) {
|
|
||||||
console.log("Setting monitoring interval to", intervalMs, "ms");
|
|
||||||
cpuTimer.interval = intervalMs;
|
|
||||||
ramTimer.interval = intervalMs;
|
|
||||||
}
|
|
||||||
|
|
||||||
function refreshSystemStats() {
|
|
||||||
console.log("Manually refreshing system stats");
|
|
||||||
cpuProcess.running = false;
|
|
||||||
cpuProcess.running = true;
|
|
||||||
ramProcess.running = false;
|
|
||||||
ramProcess.running = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Process state queries
|
|
||||||
function isShutdownRunning() {
|
|
||||||
return shutdownProcess.running;
|
|
||||||
}
|
|
||||||
function isRebootRunning() {
|
|
||||||
return rebootProcess.running;
|
|
||||||
}
|
|
||||||
function isLogoutRunning() {
|
|
||||||
return logoutProcess.running;
|
|
||||||
}
|
|
||||||
function isPavuControlRunning() {
|
|
||||||
return pavucontrolProcess.running;
|
|
||||||
}
|
|
||||||
function isMonitoringActive() {
|
|
||||||
return cpuTimer.running && ramTimer.running;
|
|
||||||
}
|
|
||||||
|
|
||||||
function stopPavuControl() {
|
|
||||||
pavucontrolProcess.running = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Formatted output helpers
|
|
||||||
function getCpuUsageFormatted() {
|
|
||||||
return Math.round(cpuUsage) + "%";
|
|
||||||
}
|
|
||||||
|
|
||||||
function getRamUsageFormatted() {
|
|
||||||
return Math.round(ramUsage) + "% (" + usedRam.toFixed(1) + "GB/" + totalRam.toFixed(1) + "GB)";
|
|
||||||
}
|
|
||||||
|
|
||||||
function getRamUsageSimple() {
|
|
||||||
return Math.round(ramUsage) + "%";
|
|
||||||
}
|
|
||||||
|
|
||||||
Component.onDestruction: {
|
|
||||||
// Stop all timers
|
|
||||||
cpuTimer.running = false;
|
|
||||||
ramTimer.running = false;
|
|
||||||
|
|
||||||
// Stop monitoring processes
|
|
||||||
cpuProcess.running = false;
|
|
||||||
ramProcess.running = false;
|
|
||||||
|
|
||||||
// Stop control processes if running
|
|
||||||
if (shutdownProcess.running)
|
|
||||||
shutdownProcess.running = false;
|
|
||||||
if (rebootProcess.running)
|
|
||||||
rebootProcess.running = false;
|
|
||||||
if (lockProcess.running)
|
|
||||||
lockProcess.running = false;
|
|
||||||
if (logoutProcess.running)
|
|
||||||
logoutProcess.running = false;
|
|
||||||
if (pavucontrolProcess.running)
|
|
||||||
pavucontrolProcess.running = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
property var service: null
|
|
||||||
|
|
||||||
// Expose current colors from the service
|
|
||||||
readonly property color primary: service?.colors?.raw?.primary || "#7ed7b8"
|
|
||||||
readonly property color on_primary: service?.colors?.raw?.on_primary || "#00382a"
|
|
||||||
readonly property color primary_container: service?.colors?.raw?.primary_container || "#454b03"
|
|
||||||
readonly property color on_primary_container: service?.colors?.raw?.on_primary_container || "#e2e993"
|
|
||||||
readonly property color secondary: service?.colors?.raw?.secondary || "#c8c9a6"
|
|
||||||
readonly property color surface_bright: service?.colors?.raw?.surface_bright || "#373b30"
|
|
||||||
readonly property bool hasColors: service?.isLoaded || false
|
|
||||||
|
|
||||||
// Expose all raw Material 3 colors for complete access
|
|
||||||
readonly property var rawColors: service?.colors?.raw || ({})
|
|
||||||
|
|
||||||
function setService(matugenService) {
|
|
||||||
service = matugenService;
|
|
||||||
console.log("MatugenManager: Service registered");
|
|
||||||
}
|
|
||||||
|
|
||||||
function reloadColors() {
|
|
||||||
if (service && service.reloadColors) {
|
|
||||||
console.log("MatugenManager: Triggering color reload");
|
|
||||||
service.reloadColors();
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
console.warn("MatugenManager: No service available for reload");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function isAvailable() {
|
|
||||||
return service !== null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,315 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import Quickshell
|
|
||||||
import QtQuick
|
|
||||||
import Quickshell.Io
|
|
||||||
|
|
||||||
Singleton {
|
|
||||||
id: settings
|
|
||||||
|
|
||||||
// Prevent auto-saving during initial load
|
|
||||||
property bool isLoading: true
|
|
||||||
|
|
||||||
// Settings persistence with atomic writes
|
|
||||||
FileView {
|
|
||||||
id: settingsFile
|
|
||||||
path: "settings.json"
|
|
||||||
blockWrites: true
|
|
||||||
atomicWrites: true
|
|
||||||
watchChanges: false
|
|
||||||
|
|
||||||
onLoaded: {
|
|
||||||
settings.isLoading = true; // Disable auto-save during loading
|
|
||||||
try {
|
|
||||||
var content = JSON.parse(text());
|
|
||||||
if (content) {
|
|
||||||
// Load with fallback defaults
|
|
||||||
settings.isDarkTheme = content.isDarkTheme ?? true;
|
|
||||||
settings.currentTheme = content.currentTheme ?? (content.isDarkTheme !== false ? "oxocarbon_dark" : "oxocarbon_light");
|
|
||||||
settings.useCustomAccent = content.useCustomAccent ?? false;
|
|
||||||
settings.avatarSource = content.avatarSource ?? "/home/imxyy/Pictures/icon.jpg";
|
|
||||||
settings.weatherLocation = content.weatherLocation ?? "Dinslaken";
|
|
||||||
settings.useFahrenheit = content.useFahrenheit ?? false;
|
|
||||||
settings.displayTime = content.displayTime ?? 6000;
|
|
||||||
settings.videoPath = content.videoPath ?? "~/Videos/";
|
|
||||||
settings.customDarkAccent = content.customDarkAccent ?? "#be95ff";
|
|
||||||
settings.customLightAccent = content.customLightAccent ?? "#8a3ffc";
|
|
||||||
settings.autoSwitchPlayer = content.autoSwitchPlayer ?? true;
|
|
||||||
settings.alwaysShowPlayerDropdown = content.alwaysShowPlayerDropdown ?? true;
|
|
||||||
settings.historyLimit = content.historyLimit ?? 25;
|
|
||||||
settings.nightLightEnabled = content.nightLightEnabled ?? false;
|
|
||||||
settings.nightLightWarmth = content.nightLightWarmth ?? 0.4;
|
|
||||||
settings.nightLightAuto = content.nightLightAuto ?? false;
|
|
||||||
settings.nightLightStartHour = content.nightLightStartHour ?? 20;
|
|
||||||
settings.nightLightEndHour = content.nightLightEndHour ?? 6;
|
|
||||||
settings.nightLightManualOverride = content.nightLightManualOverride ?? false;
|
|
||||||
settings.nightLightManuallyEnabled = content.nightLightManuallyEnabled ?? false;
|
|
||||||
settings.ignoredApps = content.ignoredApps ?? [];
|
|
||||||
settings.workspaceBurstEnabled = content.workspaceBurstEnabled ?? true;
|
|
||||||
settings.workspaceGlowEnabled = content.workspaceGlowEnabled ?? true;
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
console.log("Error parsing user settings:", e);
|
|
||||||
}
|
|
||||||
// Re-enable auto-save after loading is complete
|
|
||||||
settings.isLoading = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// User-configurable settings
|
|
||||||
property string avatarSource: "/home/imxyy/Pictures/icon.jpg"
|
|
||||||
property bool isDarkTheme: true // Keep for backwards compatibility
|
|
||||||
property string currentTheme: "oxocarbon_dark" // New theme system
|
|
||||||
property bool useCustomAccent: false // Whether to use custom accent colors
|
|
||||||
property string weatherLocation: "Dinslaken"
|
|
||||||
property bool useFahrenheit: false // Temperature unit setting
|
|
||||||
property int displayTime: 6000 // Notification display time in ms
|
|
||||||
property var ignoredApps: [] // Apps to ignore notifications from (case-insensitive)
|
|
||||||
property int historyLimit: 25 // Notification history limit
|
|
||||||
property string videoPath: "~/Videos/"
|
|
||||||
property string customDarkAccent: "#be95ff"
|
|
||||||
property string customLightAccent: "#8a3ffc"
|
|
||||||
|
|
||||||
// Music Player settings
|
|
||||||
property bool autoSwitchPlayer: true
|
|
||||||
property bool alwaysShowPlayerDropdown: true
|
|
||||||
|
|
||||||
// Night Light settings
|
|
||||||
property bool nightLightEnabled: false
|
|
||||||
property real nightLightWarmth: 0.4
|
|
||||||
property bool nightLightAuto: false
|
|
||||||
property int nightLightStartHour: 20 // 8 PM
|
|
||||||
property int nightLightEndHour: 6 // 6 AM
|
|
||||||
property bool nightLightManualOverride: false // Track manual user actions
|
|
||||||
property bool nightLightManuallyEnabled: false // Track if user manually enabled it
|
|
||||||
|
|
||||||
// Animation settings
|
|
||||||
property bool workspaceBurstEnabled: true
|
|
||||||
property bool workspaceGlowEnabled: true
|
|
||||||
|
|
||||||
// UI constants
|
|
||||||
readonly property real borderWidth: 9
|
|
||||||
readonly property real cornerRadius: 20
|
|
||||||
|
|
||||||
signal settingsChanged
|
|
||||||
|
|
||||||
// Helper functions for managing ignored apps
|
|
||||||
function addIgnoredApp(appName) {
|
|
||||||
if (appName && appName.trim() !== "") {
|
|
||||||
var trimmedName = appName.trim();
|
|
||||||
// Case-insensitive check for existing apps
|
|
||||||
var exists = false;
|
|
||||||
for (var i = 0; i < ignoredApps.length; i++) {
|
|
||||||
if (ignoredApps[i].toLowerCase() === trimmedName.toLowerCase()) {
|
|
||||||
exists = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!exists) {
|
|
||||||
var newApps = ignoredApps.slice(); // Create a copy
|
|
||||||
newApps.push(trimmedName);
|
|
||||||
ignoredApps = newApps;
|
|
||||||
console.log("Added ignored app:", trimmedName, "Current list:", ignoredApps);
|
|
||||||
// Force save immediately (only if not loading)
|
|
||||||
if (!isLoading) {
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function removeIgnoredApp(appName) {
|
|
||||||
var index = ignoredApps.indexOf(appName);
|
|
||||||
if (index > -1) {
|
|
||||||
var newApps = ignoredApps.slice(); // Create a copy
|
|
||||||
newApps.splice(index, 1);
|
|
||||||
ignoredApps = newApps;
|
|
||||||
console.log("Removed ignored app:", appName, "Current list:", ignoredApps);
|
|
||||||
// Force save immediately (only if not loading)
|
|
||||||
if (!isLoading) {
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function saveSettings() {
|
|
||||||
try {
|
|
||||||
var content = {
|
|
||||||
isDarkTheme: settings.isDarkTheme,
|
|
||||||
currentTheme: settings.currentTheme,
|
|
||||||
useCustomAccent: settings.useCustomAccent,
|
|
||||||
avatarSource: settings.avatarSource,
|
|
||||||
weatherLocation: settings.weatherLocation,
|
|
||||||
useFahrenheit: settings.useFahrenheit,
|
|
||||||
displayTime: settings.displayTime,
|
|
||||||
videoPath: settings.videoPath,
|
|
||||||
customDarkAccent: settings.customDarkAccent,
|
|
||||||
customLightAccent: settings.customLightAccent,
|
|
||||||
autoSwitchPlayer: settings.autoSwitchPlayer,
|
|
||||||
alwaysShowPlayerDropdown: settings.alwaysShowPlayerDropdown,
|
|
||||||
historyLimit: settings.historyLimit,
|
|
||||||
nightLightEnabled: settings.nightLightEnabled,
|
|
||||||
nightLightWarmth: settings.nightLightWarmth,
|
|
||||||
nightLightAuto: settings.nightLightAuto,
|
|
||||||
nightLightStartHour: settings.nightLightStartHour,
|
|
||||||
nightLightEndHour: settings.nightLightEndHour,
|
|
||||||
nightLightManualOverride: settings.nightLightManualOverride,
|
|
||||||
nightLightManuallyEnabled: settings.nightLightManuallyEnabled,
|
|
||||||
ignoredApps: settings.ignoredApps,
|
|
||||||
workspaceBurstEnabled: settings.workspaceBurstEnabled,
|
|
||||||
workspaceGlowEnabled: settings.workspaceGlowEnabled
|
|
||||||
};
|
|
||||||
var jsonContent = JSON.stringify(content, null, 4);
|
|
||||||
settingsFile.setText(jsonContent);
|
|
||||||
} catch (e) {
|
|
||||||
console.log("Error saving user settings:", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Auto-save watchers (only save when not loading)
|
|
||||||
onIsDarkThemeChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onCurrentThemeChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onUseCustomAccentChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onAvatarSourceChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onWeatherLocationChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onUseFahrenheitChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onDisplayTimeChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onHistoryLimitChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onVideoPathChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onCustomDarkAccentChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onCustomLightAccentChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onAutoSwitchPlayerChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onAlwaysShowPlayerDropdownChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightEnabledChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightWarmthChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightAutoChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightStartHourChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightEndHourChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightManualOverrideChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onNightLightManuallyEnabledChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onIgnoredAppsChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onWorkspaceBurstEnabledChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
onWorkspaceGlowEnabledChanged: {
|
|
||||||
if (!isLoading) {
|
|
||||||
settingsChanged();
|
|
||||||
saveSettings();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Component.onCompleted: {
|
|
||||||
settingsFile.reload();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,240 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
import Quickshell
|
|
||||||
import Quickshell.Io
|
|
||||||
import "Themes" as Themes
|
|
||||||
|
|
||||||
Singleton {
|
|
||||||
id: themeManager
|
|
||||||
|
|
||||||
// Import all theme definitions
|
|
||||||
property var oxocarbon: Themes.Oxocarbon
|
|
||||||
property var dracula: Themes.Dracula
|
|
||||||
property var gruvbox: Themes.Gruvbox
|
|
||||||
property var catppuccin: Themes.Catppuccin
|
|
||||||
property var matugen: Themes.Matugen
|
|
||||||
|
|
||||||
// Available theme definitions
|
|
||||||
readonly property var themes: ({
|
|
||||||
"oxocarbon_dark": oxocarbon.dark,
|
|
||||||
"oxocarbon_light": oxocarbon.light,
|
|
||||||
"dracula_dark": dracula.dark,
|
|
||||||
"dracula_light": dracula.light,
|
|
||||||
"gruvbox_dark": gruvbox.dark,
|
|
||||||
"gruvbox_light": gruvbox.light,
|
|
||||||
"catppuccin_dark": catppuccin.dark,
|
|
||||||
"catppuccin_light": catppuccin.light,
|
|
||||||
"matugen_dark": matugen.dark,
|
|
||||||
"matugen_light": matugen.light
|
|
||||||
})
|
|
||||||
|
|
||||||
// Current theme selection - defaults to oxocarbon_dark if not set
|
|
||||||
readonly property string currentThemeId: Settings.currentTheme || "oxocarbon_dark"
|
|
||||||
readonly property var currentTheme: themes[currentThemeId] || themes["oxocarbon_dark"]
|
|
||||||
|
|
||||||
// Auto-update accents when Matugen colors change
|
|
||||||
Connections {
|
|
||||||
target: MatugenManager
|
|
||||||
function onPrimaryChanged() {
|
|
||||||
if (currentThemeId.startsWith("matugen_")) {
|
|
||||||
updateMatugenAccents();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Connect to MatugenService signals for automatic accent updates
|
|
||||||
Connections {
|
|
||||||
target: MatugenManager.service
|
|
||||||
function onMatugenColorsUpdated() {
|
|
||||||
if (currentThemeId.startsWith("matugen_")) {
|
|
||||||
console.log("ThemeManager: Received matugen colors update signal");
|
|
||||||
updateMatugenAccents();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize currentTheme in settings if not present
|
|
||||||
Component.onCompleted: {
|
|
||||||
if (!Settings.currentTheme) {
|
|
||||||
console.log("Initializing currentTheme in settings");
|
|
||||||
Settings.currentTheme = "oxocarbon_dark";
|
|
||||||
Settings.saveSettings();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Matugen theme is now self-contained with service-based colors
|
|
||||||
console.log("Matugen theme initialized with service-based colors");
|
|
||||||
|
|
||||||
// Update accents if already using matugen theme
|
|
||||||
if (currentThemeId.startsWith("matugen_")) {
|
|
||||||
updateMatugenAccents();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Custom accent colors (can be changed by user)
|
|
||||||
property string customDarkAccent: Settings.customDarkAccent || "#be95ff"
|
|
||||||
property string customLightAccent: Settings.customLightAccent || "#8a3ffc"
|
|
||||||
|
|
||||||
// Dynamic color properties based on current theme
|
|
||||||
readonly property color base00: currentTheme.base00
|
|
||||||
readonly property color base01: currentTheme.base01
|
|
||||||
readonly property color base02: currentTheme.base02
|
|
||||||
readonly property color base03: currentTheme.base03
|
|
||||||
readonly property color base04: currentTheme.base04
|
|
||||||
readonly property color base05: currentTheme.base05
|
|
||||||
readonly property color base06: currentTheme.base06
|
|
||||||
readonly property color base07: currentTheme.base07
|
|
||||||
readonly property color base08: currentTheme.base08
|
|
||||||
readonly property color base09: currentTheme.base09
|
|
||||||
readonly property color base0A: currentTheme.base0A
|
|
||||||
readonly property color base0B: currentTheme.base0B
|
|
||||||
readonly property color base0C: currentTheme.base0C
|
|
||||||
readonly property color base0D: currentTheme.base0D
|
|
||||||
readonly property color base0E: Settings.useCustomAccent ? (currentTheme.type === "dark" ? customDarkAccent : customLightAccent) : currentTheme.base0E
|
|
||||||
readonly property color base0F: currentTheme.base0F
|
|
||||||
|
|
||||||
// Common UI color mappings
|
|
||||||
readonly property color bgColor: base00
|
|
||||||
readonly property color bgLight: base01
|
|
||||||
readonly property color bgLighter: base02
|
|
||||||
readonly property color fgColor: base04
|
|
||||||
readonly property color fgColorBright: base05
|
|
||||||
readonly property color accentColor: base0E
|
|
||||||
readonly property color accentColorBright: base0D
|
|
||||||
readonly property color highlightBg: Qt.rgba(base0E.r, base0E.g, base0E.b, 0.15)
|
|
||||||
readonly property color errorColor: base08
|
|
||||||
readonly property color greenColor: base0B
|
|
||||||
readonly property color redColor: base08
|
|
||||||
|
|
||||||
// Alternative semantic aliases for convenience
|
|
||||||
readonly property color background: base00
|
|
||||||
readonly property color panelBackground: base01
|
|
||||||
readonly property color selection: base02
|
|
||||||
readonly property color border: base03
|
|
||||||
readonly property color secondaryText: base04
|
|
||||||
readonly property color primaryText: base05
|
|
||||||
readonly property color brightText: base06
|
|
||||||
readonly property color brightestText: base07
|
|
||||||
readonly property color error: base08
|
|
||||||
readonly property color warning: base09
|
|
||||||
readonly property color highlight: base0A
|
|
||||||
readonly property color success: base0B
|
|
||||||
readonly property color info: base0C
|
|
||||||
readonly property color primary: base0D
|
|
||||||
readonly property color accent: base0E
|
|
||||||
readonly property color special: base0F
|
|
||||||
|
|
||||||
// UI styling constants
|
|
||||||
readonly property real borderWidth: 9
|
|
||||||
readonly property real cornerRadius: 20
|
|
||||||
|
|
||||||
// Color utility functions
|
|
||||||
function withOpacity(color, opacity) {
|
|
||||||
return Qt.rgba(color.r, color.g, color.b, opacity);
|
|
||||||
}
|
|
||||||
|
|
||||||
function withHighlight(color) {
|
|
||||||
return Qt.rgba(color.r, color.g, color.b, 0.15);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Theme management functions
|
|
||||||
function setTheme(themeId) {
|
|
||||||
if (themes[themeId]) {
|
|
||||||
const previousThemeId = Settings.currentTheme;
|
|
||||||
Settings.currentTheme = themeId;
|
|
||||||
|
|
||||||
// Check if switching between matugen light/dark modes
|
|
||||||
if (themeId.startsWith("matugen_") && previousThemeId && previousThemeId.startsWith("matugen_")) {
|
|
||||||
const newMode = themeId.includes("_light") ? "light" : "dark";
|
|
||||||
const oldMode = previousThemeId.includes("_light") ? "light" : "dark";
|
|
||||||
|
|
||||||
if (newMode !== oldMode) {
|
|
||||||
console.log(`🎨 Switching matugen from ${oldMode} to ${newMode} mode`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Auto-update accents for Matugen themes
|
|
||||||
if (themeId.startsWith("matugen_")) {
|
|
||||||
updateMatugenAccents();
|
|
||||||
}
|
|
||||||
|
|
||||||
Settings.saveSettings();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Auto-update accent colors when using Matugen theme
|
|
||||||
function updateMatugenAccents() {
|
|
||||||
if (MatugenManager.isAvailable() && MatugenManager.hasColors) {
|
|
||||||
// Get colors from the raw matugen palette
|
|
||||||
const rawColors = MatugenManager.rawColors;
|
|
||||||
|
|
||||||
// Use primary for both dark and light themes - it's generated appropriately by matugen
|
|
||||||
const accent = rawColors.primary;
|
|
||||||
|
|
||||||
// Debug log the colors we're using
|
|
||||||
console.log("Raw colors available:", Object.keys(rawColors));
|
|
||||||
console.log("Selected accent for both themes:", accent);
|
|
||||||
|
|
||||||
// Update custom accents - use the same accent for both
|
|
||||||
setCustomAccent(accent, accent);
|
|
||||||
|
|
||||||
// Enable custom accents for Matugen theme
|
|
||||||
Settings.useCustomAccent = true;
|
|
||||||
Settings.saveSettings();
|
|
||||||
|
|
||||||
console.log("Auto-updated Matugen accents from service:", accent);
|
|
||||||
} else {
|
|
||||||
console.log("MatugenManager service not available or no colors loaded yet");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function getThemeList() {
|
|
||||||
return Object.keys(themes).map(function (key) {
|
|
||||||
return {
|
|
||||||
id: key,
|
|
||||||
name: themes[key].name,
|
|
||||||
type: themes[key].type
|
|
||||||
};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function getDarkThemes() {
|
|
||||||
return getThemeList().filter(function (theme) {
|
|
||||||
return theme.type === "dark";
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function getLightThemes() {
|
|
||||||
return getThemeList().filter(function (theme) {
|
|
||||||
return theme.type === "light";
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function setCustomAccent(darkColor, lightColor) {
|
|
||||||
customDarkAccent = darkColor;
|
|
||||||
customLightAccent = lightColor;
|
|
||||||
Settings.customDarkAccent = darkColor;
|
|
||||||
Settings.customLightAccent = lightColor;
|
|
||||||
Settings.saveSettings();
|
|
||||||
}
|
|
||||||
|
|
||||||
function toggleCustomAccent() {
|
|
||||||
Settings.useCustomAccent = !Settings.useCustomAccent;
|
|
||||||
Settings.saveSettings();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Legacy function for backwards compatibility
|
|
||||||
function toggleTheme() {
|
|
||||||
// Switch between dark and light variants of current theme family
|
|
||||||
var currentFamily = currentThemeId.replace(/_dark|_light/, "");
|
|
||||||
var newThemeId = currentTheme.type === "dark" ? currentFamily + "_light" : currentFamily + "_dark";
|
|
||||||
|
|
||||||
// If the opposite variant doesn't exist, switch to oxocarbon
|
|
||||||
if (!themes[newThemeId]) {
|
|
||||||
newThemeId = currentTheme.type === "dark" ? "oxocarbon_light" : "oxocarbon_dark";
|
|
||||||
}
|
|
||||||
|
|
||||||
setTheme(newThemeId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
readonly property var dark: ({
|
|
||||||
name: "Catppuccin Mocha",
|
|
||||||
type: "dark",
|
|
||||||
base00: "#1e1e2e" // Base
|
|
||||||
,
|
|
||||||
base01: "#181825" // Mantle
|
|
||||||
,
|
|
||||||
base02: "#313244" // Surface0
|
|
||||||
,
|
|
||||||
base03: "#45475a" // Surface1
|
|
||||||
,
|
|
||||||
base04: "#585b70" // Surface2
|
|
||||||
,
|
|
||||||
base05: "#cdd6f4" // Text
|
|
||||||
,
|
|
||||||
base06: "#f5e0dc" // Rosewater
|
|
||||||
,
|
|
||||||
base07: "#b4befe" // Lavender
|
|
||||||
,
|
|
||||||
base08: "#f38ba8" // Red
|
|
||||||
,
|
|
||||||
base09: "#fab387" // Peach
|
|
||||||
,
|
|
||||||
base0A: "#f9e2af" // Yellow
|
|
||||||
,
|
|
||||||
base0B: "#a6e3a1" // Green
|
|
||||||
,
|
|
||||||
base0C: "#94e2d5" // Teal
|
|
||||||
,
|
|
||||||
base0D: "#89b4fa" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#cba6f7" // Mauve
|
|
||||||
,
|
|
||||||
base0F: "#f2cdcd" // Flamingo
|
|
||||||
})
|
|
||||||
|
|
||||||
readonly property var light: ({
|
|
||||||
name: "Catppuccin Latte",
|
|
||||||
type: "light",
|
|
||||||
base00: "#eff1f5" // Base
|
|
||||||
,
|
|
||||||
base01: "#e6e9ef" // Mantle
|
|
||||||
,
|
|
||||||
base02: "#ccd0da" // Surface0
|
|
||||||
,
|
|
||||||
base03: "#bcc0cc" // Surface1
|
|
||||||
,
|
|
||||||
base04: "#acb0be" // Surface2
|
|
||||||
,
|
|
||||||
base05: "#4c4f69" // Text
|
|
||||||
,
|
|
||||||
base06: "#dc8a78" // Rosewater
|
|
||||||
,
|
|
||||||
base07: "#7287fd" // Lavender
|
|
||||||
,
|
|
||||||
base08: "#d20f39" // Red
|
|
||||||
,
|
|
||||||
base09: "#fe640b" // Peach
|
|
||||||
,
|
|
||||||
base0A: "#df8e1d" // Yellow
|
|
||||||
,
|
|
||||||
base0B: "#40a02b" // Green
|
|
||||||
,
|
|
||||||
base0C: "#179299" // Teal
|
|
||||||
,
|
|
||||||
base0D: "#1e66f5" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#8839ef" // Mauve
|
|
||||||
,
|
|
||||||
base0F: "#dd7878" // Flamingo
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
readonly property var dark: ({
|
|
||||||
name: "Dracula",
|
|
||||||
type: "dark",
|
|
||||||
base00: "#282a36" // Background
|
|
||||||
,
|
|
||||||
base01: "#44475a" // Current line
|
|
||||||
,
|
|
||||||
base02: "#565761" // Selection
|
|
||||||
,
|
|
||||||
base03: "#6272a4" // Comment
|
|
||||||
,
|
|
||||||
base04: "#6272a4" // Dark foreground
|
|
||||||
,
|
|
||||||
base05: "#f8f8f2" // Foreground
|
|
||||||
,
|
|
||||||
base06: "#f8f8f2" // Light foreground
|
|
||||||
,
|
|
||||||
base07: "#ffffff" // Light background
|
|
||||||
,
|
|
||||||
base08: "#ff5555" // Red
|
|
||||||
,
|
|
||||||
base09: "#ffb86c" // Orange
|
|
||||||
,
|
|
||||||
base0A: "#f1fa8c" // Yellow
|
|
||||||
,
|
|
||||||
base0B: "#50fa7b" // Green
|
|
||||||
,
|
|
||||||
base0C: "#8be9fd" // Cyan
|
|
||||||
,
|
|
||||||
base0D: "#bd93f9" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#ff79c6" // Magenta
|
|
||||||
,
|
|
||||||
base0F: "#ffb86c" // Orange
|
|
||||||
})
|
|
||||||
|
|
||||||
readonly property var light: ({
|
|
||||||
name: "Dracula Light",
|
|
||||||
type: "light",
|
|
||||||
base00: "#f8f8f2" // Light background
|
|
||||||
,
|
|
||||||
base01: "#ffffff" // Lighter background
|
|
||||||
,
|
|
||||||
base02: "#e5e5e5" // Selection
|
|
||||||
,
|
|
||||||
base03: "#bfbfbf" // Comment
|
|
||||||
,
|
|
||||||
base04: "#6272a4" // Dark foreground
|
|
||||||
,
|
|
||||||
base05: "#282a36" // Dark text
|
|
||||||
,
|
|
||||||
base06: "#21222c" // Darker text
|
|
||||||
,
|
|
||||||
base07: "#191a21" // Darkest
|
|
||||||
,
|
|
||||||
base08: "#e74c3c" // Red (adjusted for light)
|
|
||||||
,
|
|
||||||
base09: "#f39c12" // Orange
|
|
||||||
,
|
|
||||||
base0A: "#f1c40f" // Yellow
|
|
||||||
,
|
|
||||||
base0B: "#27ae60" // Green
|
|
||||||
,
|
|
||||||
base0C: "#17a2b8" // Cyan
|
|
||||||
,
|
|
||||||
base0D: "#6c7ce0" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#e91e63" // Magenta
|
|
||||||
,
|
|
||||||
base0F: "#f39c12" // Orange
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
readonly property var dark: ({
|
|
||||||
name: "Gruvbox Dark",
|
|
||||||
type: "dark",
|
|
||||||
base00: "#282828" // Dark background
|
|
||||||
,
|
|
||||||
base01: "#3c3836" // Dark1
|
|
||||||
,
|
|
||||||
base02: "#504945" // Dark2
|
|
||||||
,
|
|
||||||
base03: "#665c54" // Dark3
|
|
||||||
,
|
|
||||||
base04: "#bdae93" // Light4
|
|
||||||
,
|
|
||||||
base05: "#d5c4a1" // Light3
|
|
||||||
,
|
|
||||||
base06: "#ebdbb2" // Light2
|
|
||||||
,
|
|
||||||
base07: "#fbf1c7" // Light1
|
|
||||||
,
|
|
||||||
base08: "#fb4934" // Red
|
|
||||||
,
|
|
||||||
base09: "#fe8019" // Orange
|
|
||||||
,
|
|
||||||
base0A: "#fabd2f" // Yellow
|
|
||||||
,
|
|
||||||
base0B: "#b8bb26" // Green
|
|
||||||
,
|
|
||||||
base0C: "#8ec07c" // Cyan
|
|
||||||
,
|
|
||||||
base0D: "#83a598" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#d3869b" // Purple
|
|
||||||
,
|
|
||||||
base0F: "#d65d0e" // Brown
|
|
||||||
})
|
|
||||||
|
|
||||||
readonly property var light: ({
|
|
||||||
name: "Gruvbox Light",
|
|
||||||
type: "light",
|
|
||||||
base00: "#fbf1c7" // Light background
|
|
||||||
,
|
|
||||||
base01: "#ebdbb2" // Light1
|
|
||||||
,
|
|
||||||
base02: "#d5c4a1" // Light2
|
|
||||||
,
|
|
||||||
base03: "#bdae93" // Light3
|
|
||||||
,
|
|
||||||
base04: "#665c54" // Dark3
|
|
||||||
,
|
|
||||||
base05: "#504945" // Dark2
|
|
||||||
,
|
|
||||||
base06: "#3c3836" // Dark1
|
|
||||||
,
|
|
||||||
base07: "#282828" // Dark background
|
|
||||||
,
|
|
||||||
base08: "#cc241d" // Red
|
|
||||||
,
|
|
||||||
base09: "#d65d0e" // Orange
|
|
||||||
,
|
|
||||||
base0A: "#d79921" // Yellow
|
|
||||||
,
|
|
||||||
base0B: "#98971a" // Green
|
|
||||||
,
|
|
||||||
base0C: "#689d6a" // Cyan
|
|
||||||
,
|
|
||||||
base0D: "#458588" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#b16286" // Purple
|
|
||||||
,
|
|
||||||
base0F: "#d65d0e" // Brown
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,141 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
// Reference to the MatugenService
|
|
||||||
property var matugenService: null
|
|
||||||
|
|
||||||
// Debug helper to check service status
|
|
||||||
function debugServiceStatus() {
|
|
||||||
console.log("🔍 Debug: matugenService =", matugenService);
|
|
||||||
console.log("🔍 Debug: matugenService.isLoaded =", matugenService ? matugenService.isLoaded : "N/A");
|
|
||||||
console.log("🔍 Debug: matugenService.colorVersion =", matugenService ? matugenService.colorVersion : "N/A");
|
|
||||||
console.log("🔍 Debug: condition result =", (matugenService && matugenService.isLoaded && matugenService.colorVersion >= 0));
|
|
||||||
if (matugenService && matugenService.colors) {
|
|
||||||
console.log("🔍 Debug: service.colors.dark =", JSON.stringify(matugenService.colors.dark));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Map matugen colors to base16 scheme - using the service when available
|
|
||||||
// The colorVersion dependency forces re-evaluation when colors update
|
|
||||||
readonly property var dark: {
|
|
||||||
debugServiceStatus();
|
|
||||||
if (matugenService && matugenService.isLoaded && matugenService.colorVersion >= 0) {
|
|
||||||
// Use service colors if available, or generate fallback if we have light colors
|
|
||||||
return matugenService.colors.dark || {
|
|
||||||
name: "Matugen Dark (Generated from Light)",
|
|
||||||
type: "dark",
|
|
||||||
// If we only have light colors, create dark fallback
|
|
||||||
base00: "#141311",
|
|
||||||
base01: "#1c1c19",
|
|
||||||
base02: "#20201d",
|
|
||||||
base03: "#2a2a27",
|
|
||||||
base04: "#c9c7ba",
|
|
||||||
base05: "#e5e2de",
|
|
||||||
base06: "#31302e",
|
|
||||||
base07: "#e5e2de",
|
|
||||||
base08: "#ffb4ab",
|
|
||||||
base09: "#b5ccb9",
|
|
||||||
base0A: "#e4e5c1",
|
|
||||||
base0B: "#c8c7b7",
|
|
||||||
base0C: "#c8c9a6",
|
|
||||||
base0D: "#c8c9a6",
|
|
||||||
base0E: "#47483b",
|
|
||||||
base0F: "#000000"
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
return {
|
|
||||||
name: "Matugen Dark",
|
|
||||||
type: "dark",
|
|
||||||
// Updated fallback colors to match current quickshell-colors.qml
|
|
||||||
base00: "#141311",
|
|
||||||
base01: "#1c1c19",
|
|
||||||
base02: "#20201d",
|
|
||||||
base03: "#2a2a27",
|
|
||||||
base04: "#c9c7ba",
|
|
||||||
base05: "#e5e2de",
|
|
||||||
base06: "#31302e",
|
|
||||||
base07: "#e5e2de",
|
|
||||||
base08: "#ffb4ab",
|
|
||||||
base09: "#b5ccb9",
|
|
||||||
base0A: "#e4e5c1",
|
|
||||||
base0B: "#c8c7b7",
|
|
||||||
base0C: "#c8c9a6",
|
|
||||||
base0D: "#c8c9a6",
|
|
||||||
base0E: "#47483b",
|
|
||||||
base0F: "#000000"
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
readonly property var light: {
|
|
||||||
if (matugenService && matugenService.isLoaded && matugenService.colorVersion >= 0) {
|
|
||||||
// Use service colors if available, or generate fallback if we have dark colors
|
|
||||||
return matugenService.colors.light || {
|
|
||||||
name: "Matugen Light (Generated from Dark)",
|
|
||||||
type: "light",
|
|
||||||
// If we only have dark colors, create light fallback
|
|
||||||
base00: "#ffffff",
|
|
||||||
base01: "#f5f5f5",
|
|
||||||
base02: "#e8e8e8",
|
|
||||||
base03: "#d0d0d0",
|
|
||||||
base04: "#666666",
|
|
||||||
base05: "#1a1a1a",
|
|
||||||
base06: "#000000",
|
|
||||||
base07: "#ffffff",
|
|
||||||
base08: "#d32f2f",
|
|
||||||
base09: "#7b1fa2",
|
|
||||||
base0A: "#f57c00",
|
|
||||||
base0B: "#388e3c",
|
|
||||||
base0C: "#0097a7",
|
|
||||||
base0D: "#1976d2",
|
|
||||||
base0E: "#5e35b1",
|
|
||||||
base0F: "#000000"
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
return {
|
|
||||||
name: "Matugen Light",
|
|
||||||
type: "light",
|
|
||||||
// Updated fallback colors based on current colors
|
|
||||||
base00: "#ffffff",
|
|
||||||
base01: "#f5f5f5",
|
|
||||||
base02: "#e8e8e8",
|
|
||||||
base03: "#d0d0d0",
|
|
||||||
base04: "#666666",
|
|
||||||
base05: "#1a1a1a",
|
|
||||||
base06: "#000000",
|
|
||||||
base07: "#ffffff",
|
|
||||||
base08: "#d32f2f",
|
|
||||||
base09: "#7b1fa2",
|
|
||||||
base0A: "#f57c00",
|
|
||||||
base0B: "#388e3c",
|
|
||||||
base0C: "#0097a7",
|
|
||||||
base0D: "#1976d2",
|
|
||||||
base0E: "#5e35b1",
|
|
||||||
base0F: "#000000"
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Direct access to primary colors for accent updates
|
|
||||||
readonly property color primary: (matugenService && matugenService.getColor && matugenService.colorVersion >= 0) ? matugenService.getColor("primary") || "#c8c9a6" : "#c8c9a6"
|
|
||||||
readonly property color on_primary: (matugenService && matugenService.getColor && matugenService.colorVersion >= 0) ? matugenService.getColor("on_primary") || "#303219" : "#303219"
|
|
||||||
|
|
||||||
// Function to set the service reference
|
|
||||||
function setMatugenService(service) {
|
|
||||||
matugenService = service;
|
|
||||||
console.log("🔌 MatugenService connected to theme:", service);
|
|
||||||
|
|
||||||
// Connect to service signals for automatic updates
|
|
||||||
if (service) {
|
|
||||||
service.matugenColorsUpdated.connect(function () {
|
|
||||||
console.log("🎨 Matugen colors updated in theme (version " + service.colorVersion + ")");
|
|
||||||
debugServiceStatus();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Component.onCompleted: {
|
|
||||||
console.log("Matugen theme loaded, waiting for MatugenService connection");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
QtObject {
|
|
||||||
readonly property var dark: ({
|
|
||||||
name: "Oxocarbon Dark",
|
|
||||||
type: "dark",
|
|
||||||
base00: "#161616" // OLED-friendly background
|
|
||||||
,
|
|
||||||
base01: "#262626" // Surface 1
|
|
||||||
,
|
|
||||||
base02: "#393939" // Surface 2
|
|
||||||
,
|
|
||||||
base03: "#525252" // Surface 3
|
|
||||||
,
|
|
||||||
base04: "#6f6f6f" // Text secondary
|
|
||||||
,
|
|
||||||
base05: "#c6c6c6" // Text primary
|
|
||||||
,
|
|
||||||
base06: "#e0e0e0" // Text on color
|
|
||||||
,
|
|
||||||
base07: "#f4f4f4" // Text inverse
|
|
||||||
,
|
|
||||||
base08: "#ff7eb6" // Red (pink)
|
|
||||||
,
|
|
||||||
base09: "#ee5396" // Magenta
|
|
||||||
,
|
|
||||||
base0A: "#42be65" // Green
|
|
||||||
,
|
|
||||||
base0B: "#be95ff" // Purple
|
|
||||||
,
|
|
||||||
base0C: "#3ddbd9" // Cyan
|
|
||||||
,
|
|
||||||
base0D: "#78a9ff" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#be95ff" // Purple (accent)
|
|
||||||
,
|
|
||||||
base0F: "#08bdba" // Teal
|
|
||||||
})
|
|
||||||
|
|
||||||
readonly property var light: ({
|
|
||||||
name: "Oxocarbon Light",
|
|
||||||
type: "light",
|
|
||||||
base00: "#f4f4f4" // Light background
|
|
||||||
,
|
|
||||||
base01: "#ffffff" // Surface 1
|
|
||||||
,
|
|
||||||
base02: "#e0e0e0" // Surface 2
|
|
||||||
,
|
|
||||||
base03: "#c6c6c6" // Surface 3
|
|
||||||
,
|
|
||||||
base04: "#525252" // Text secondary
|
|
||||||
,
|
|
||||||
base05: "#262626" // Text primary
|
|
||||||
,
|
|
||||||
base06: "#161616" // Text on color
|
|
||||||
,
|
|
||||||
base07: "#000000" // Text inverse
|
|
||||||
,
|
|
||||||
base08: "#da1e28" // Red
|
|
||||||
,
|
|
||||||
base09: "#d12771" // Magenta
|
|
||||||
,
|
|
||||||
base0A: "#198038" // Green
|
|
||||||
,
|
|
||||||
base0B: "#8a3ffc" // Purple
|
|
||||||
,
|
|
||||||
base0C: "#007d79" // Cyan
|
|
||||||
,
|
|
||||||
base0D: "#0f62fe" // Blue
|
|
||||||
,
|
|
||||||
base0E: "#8a3ffc" // Purple (accent)
|
|
||||||
,
|
|
||||||
base0F: "#005d5d" // Teal
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,60 +0,0 @@
|
|||||||
pragma Singleton
|
|
||||||
import Quickshell
|
|
||||||
import QtQuick
|
|
||||||
|
|
||||||
Singleton {
|
|
||||||
readonly property color background: "#13140c"
|
|
||||||
readonly property color error: "#ffb4ab"
|
|
||||||
readonly property color error_container: "#93000a"
|
|
||||||
readonly property color inverse_on_surface: "#313128"
|
|
||||||
readonly property color inverse_primary: "#5d631c"
|
|
||||||
readonly property color inverse_surface: "#e5e3d6"
|
|
||||||
readonly property color on_background: "#e5e3d6"
|
|
||||||
readonly property color on_error: "#690005"
|
|
||||||
readonly property color on_error_container: "#ffdad6"
|
|
||||||
readonly property color on_primary: "#2f3300"
|
|
||||||
readonly property color on_primary_container: "#e2e993"
|
|
||||||
readonly property color on_primary_fixed: "#1b1d00"
|
|
||||||
readonly property color on_primary_fixed_variant: "#454b03"
|
|
||||||
readonly property color on_secondary: "#30321a"
|
|
||||||
readonly property color on_secondary_container: "#e4e5c1"
|
|
||||||
readonly property color on_secondary_fixed: "#1b1d07"
|
|
||||||
readonly property color on_secondary_fixed_variant: "#47492e"
|
|
||||||
readonly property color on_surface: "#e5e3d6"
|
|
||||||
readonly property color on_surface_variant: "#c8c7b7"
|
|
||||||
readonly property color on_tertiary: "#07372c"
|
|
||||||
readonly property color on_tertiary_container: "#beecdc"
|
|
||||||
readonly property color on_tertiary_fixed: "#002019"
|
|
||||||
readonly property color on_tertiary_fixed_variant: "#234e42"
|
|
||||||
readonly property color outline: "#929182"
|
|
||||||
readonly property color outline_variant: "#47483b"
|
|
||||||
readonly property color primary: "#c5cc7a"
|
|
||||||
readonly property color primary_container: "#454b03"
|
|
||||||
readonly property color primary_fixed: "#e2e993"
|
|
||||||
readonly property color primary_fixed_dim: "#c5cc7a"
|
|
||||||
readonly property color scrim: "#000000"
|
|
||||||
readonly property color secondary: "#c8c9a6"
|
|
||||||
readonly property color secondary_container: "#47492e"
|
|
||||||
readonly property color secondary_fixed: "#e4e5c1"
|
|
||||||
readonly property color secondary_fixed_dim: "#c8c9a6"
|
|
||||||
readonly property color shadow: "#000000"
|
|
||||||
readonly property color surface: "#13140c"
|
|
||||||
readonly property color surface_bright: "#3a3a31"
|
|
||||||
readonly property color surface_container: "#202018"
|
|
||||||
readonly property color surface_container_high: "#2a2a22"
|
|
||||||
readonly property color surface_container_highest: "#35352c"
|
|
||||||
readonly property color surface_container_low: "#1c1c14"
|
|
||||||
readonly property color surface_container_lowest: "#0e0f08"
|
|
||||||
readonly property color surface_dim: "#13140c"
|
|
||||||
readonly property color surface_tint: "#c5cc7a"
|
|
||||||
|
|
||||||
readonly property color surface_variant: "#47483b"
|
|
||||||
readonly property color tertiary: "#a3d0c0"
|
|
||||||
readonly property color tertiary_container: "#234e42"
|
|
||||||
readonly property color tertiary_fixed: "#beecdc"
|
|
||||||
readonly property color tertiary_fixed_dim: "#a3d0c0"
|
|
||||||
|
|
||||||
function withAlpha(color: color, alpha: real): color {
|
|
||||||
return Qt.rgba(color.r, color.g, color.b, alpha);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
{
|
|
||||||
"isDarkTheme": true,
|
|
||||||
"avatarSource": "/home/imxyy/Pictures/icon.jpg",
|
|
||||||
"weatherLocation": "Dinslaken",
|
|
||||||
"displayTime": 6000,
|
|
||||||
"videoPath": "~/Videos/"
|
|
||||||
}
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
import QtQuick
|
|
||||||
import QtQuick.Effects
|
|
||||||
import "root:/Data" as Data
|
|
||||||
import "root:/Widgets/System" as System
|
|
||||||
import "root:/Widgets/Calendar" as Calendar
|
|
||||||
|
|
||||||
// Vertical sidebar layout
|
|
||||||
Rectangle {
|
|
||||||
id: bar
|
|
||||||
|
|
||||||
// Clean bar background
|
|
||||||
color: Data.ThemeManager.bgColor
|
|
||||||
|
|
||||||
// Workspace indicator at top
|
|
||||||
System.NiriWorkspaces {
|
|
||||||
id: workspaceIndicator
|
|
||||||
anchors {
|
|
||||||
top: parent.top
|
|
||||||
horizontalCenter: parent.horizontalCenter
|
|
||||||
horizontalCenterOffset: Data.Settings.borderWidth / 2
|
|
||||||
topMargin: 20
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Clock at bottom
|
|
||||||
Calendar.Clock {
|
|
||||||
id: clockWidget
|
|
||||||
anchors {
|
|
||||||
bottom: parent.bottom
|
|
||||||
horizontalCenter: parent.horizontalCenter
|
|
||||||
horizontalCenterOffset: Data.Settings.borderWidth / 2
|
|
||||||
bottomMargin: 20
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,575 +0,0 @@
|
|||||||
import QtQuick
|
|
||||||
import QtQuick.Shapes
|
|
||||||
import Qt5Compat.GraphicalEffects
|
|
||||||
import QtQuick.Effects
|
|
||||||
import "root:/Data" as Data
|
|
||||||
|
|
||||||
// Screen border with shadow effects
|
|
||||||
Shape {
|
|
||||||
id: borderShape
|
|
||||||
|
|
||||||
// Border dimensions
|
|
||||||
property real borderWidth: Data.Settings.borderWidth
|
|
||||||
property real radius: Data.Settings.cornerRadius
|
|
||||||
property real innerX: borderWidth
|
|
||||||
property real innerY: borderWidth
|
|
||||||
property real innerWidth: borderShape.width - (borderWidth * 2)
|
|
||||||
property real innerHeight: borderShape.height - (borderWidth * 2)
|
|
||||||
|
|
||||||
// Widget references for shadow positioning
|
|
||||||
property var workspaceIndicator: null
|
|
||||||
property var volumeOSD: null
|
|
||||||
property var clockWidget: null
|
|
||||||
|
|
||||||
// Initialization state to prevent ShaderEffect warnings
|
|
||||||
property bool effectsReady: false
|
|
||||||
|
|
||||||
// Burst effect properties - controlled by workspace indicator
|
|
||||||
property real masterProgress: workspaceIndicator ? workspaceIndicator.masterProgress : 0.0
|
|
||||||
property bool effectsActive: workspaceIndicator ? workspaceIndicator.effectsActive : false
|
|
||||||
property color effectColor: workspaceIndicator ? workspaceIndicator.effectColor : Data.ThemeManager.accent
|
|
||||||
|
|
||||||
// Delay graphics effects until component is fully loaded
|
|
||||||
Timer {
|
|
||||||
id: initTimer
|
|
||||||
interval: 100
|
|
||||||
running: true
|
|
||||||
onTriggered: borderShape.effectsReady = true
|
|
||||||
}
|
|
||||||
|
|
||||||
// Burst effect overlays (DISABLED - using unified overlay)
|
|
||||||
Item {
|
|
||||||
id: burstEffects
|
|
||||||
anchors.fill: parent
|
|
||||||
visible: false // Disabled in favor of unified overlay
|
|
||||||
z: 5
|
|
||||||
}
|
|
||||||
|
|
||||||
// Individual widget shadows (positioned separately)
|
|
||||||
|
|
||||||
// Workspace indicator shadow
|
|
||||||
Shape {
|
|
||||||
id: workspaceDropShadow
|
|
||||||
visible: borderShape.workspaceIndicator !== null
|
|
||||||
x: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.x : 0 // Exact match
|
|
||||||
y: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.y : 0
|
|
||||||
width: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.width : 0 // Exact match
|
|
||||||
height: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.height : 0
|
|
||||||
z: -1
|
|
||||||
|
|
||||||
layer.enabled: borderShape.workspaceIndicator !== null
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: 1
|
|
||||||
verticalOffset: 1
|
|
||||||
radius: 12 + (effectsActive && Data.Settings.workspaceGlowEnabled ? Math.sin(masterProgress * Math.PI) * 4 : 0)
|
|
||||||
samples: 25
|
|
||||||
color: {
|
|
||||||
if (!effectsActive)
|
|
||||||
return Qt.rgba(0, 0, 0, 0.4);
|
|
||||||
if (!Data.Settings.workspaceGlowEnabled)
|
|
||||||
return Qt.rgba(0, 0, 0, 0.4);
|
|
||||||
// Use accent color directly with reduced intensity
|
|
||||||
const intensity = Math.sin(masterProgress * Math.PI) * 0.4;
|
|
||||||
return Qt.rgba(effectColor.r * intensity + 0.08, effectColor.g * intensity + 0.08, effectColor.b * intensity + 0.08, 0.4 + intensity * 0.2);
|
|
||||||
}
|
|
||||||
cached: true
|
|
||||||
spread: 0.2 + (effectsActive && Data.Settings.workspaceGlowEnabled ? Math.sin(masterProgress * Math.PI) * 0.15 : 0)
|
|
||||||
}
|
|
||||||
|
|
||||||
ShapePath {
|
|
||||||
strokeWidth: 0
|
|
||||||
fillColor: "black"
|
|
||||||
|
|
||||||
startX: 12
|
|
||||||
startY: 0
|
|
||||||
|
|
||||||
// Right side - standard rounded corners
|
|
||||||
PathLine {
|
|
||||||
x: workspaceDropShadow.width - 16
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: workspaceDropShadow.width
|
|
||||||
y: 16
|
|
||||||
radiusX: 16
|
|
||||||
radiusY: 16
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: workspaceDropShadow.width
|
|
||||||
y: workspaceDropShadow.height - 16
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: workspaceDropShadow.width - 16
|
|
||||||
y: workspaceDropShadow.height
|
|
||||||
radiusX: 16
|
|
||||||
radiusY: 16
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: 12
|
|
||||||
y: workspaceDropShadow.height
|
|
||||||
}
|
|
||||||
|
|
||||||
// Left side - concave curves for border integration
|
|
||||||
PathLine {
|
|
||||||
x: 0
|
|
||||||
y: workspaceDropShadow.height - 12
|
|
||||||
}
|
|
||||||
PathArc {
|
|
||||||
x: 12
|
|
||||||
y: workspaceDropShadow.height - 24
|
|
||||||
radiusX: 12
|
|
||||||
radiusY: 12
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: 12
|
|
||||||
y: 24
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: 0
|
|
||||||
y: 12
|
|
||||||
radiusX: 12
|
|
||||||
radiusY: 12
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: 12
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Volume OSD shadow
|
|
||||||
Rectangle {
|
|
||||||
id: volumeOsdDropShadow
|
|
||||||
visible: borderShape.volumeOSD !== null && borderShape.volumeOSD.visible
|
|
||||||
opacity: borderShape.volumeOSD ? borderShape.volumeOSD.opacity : 0
|
|
||||||
x: parent.width - 45
|
|
||||||
y: (parent.height - 250) / 2
|
|
||||||
width: 45
|
|
||||||
height: 250
|
|
||||||
color: "black"
|
|
||||||
topLeftRadius: 20
|
|
||||||
bottomLeftRadius: 20
|
|
||||||
topRightRadius: 0
|
|
||||||
bottomRightRadius: 0
|
|
||||||
z: -1
|
|
||||||
|
|
||||||
// Sync opacity animations with volume OSD
|
|
||||||
Behavior on opacity {
|
|
||||||
NumberAnimation {
|
|
||||||
duration: 300
|
|
||||||
easing.type: Easing.OutCubic
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
layer.enabled: borderShape.volumeOSD !== null
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: -1
|
|
||||||
verticalOffset: 1
|
|
||||||
radius: 12 // Much more subtle
|
|
||||||
samples: 25
|
|
||||||
color: Qt.rgba(0, 0, 0, 0.4) // Very light shadow
|
|
||||||
cached: false
|
|
||||||
spread: 0.2 // Minimal spread
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Clock shadow
|
|
||||||
Rectangle {
|
|
||||||
id: clockDropShadow
|
|
||||||
visible: borderShape.clockWidget !== null
|
|
||||||
x: borderShape.clockWidget ? borderShape.clockWidget.x : 0
|
|
||||||
y: borderShape.clockWidget ? borderShape.clockWidget.y : 0
|
|
||||||
width: borderShape.clockWidget ? borderShape.clockWidget.width : 0
|
|
||||||
height: borderShape.clockWidget ? borderShape.clockWidget.height : 0
|
|
||||||
color: "black"
|
|
||||||
topLeftRadius: 0
|
|
||||||
topRightRadius: borderShape.clockWidget ? borderShape.clockWidget.height / 2 : 16
|
|
||||||
bottomLeftRadius: 0
|
|
||||||
bottomRightRadius: 0
|
|
||||||
z: -2 // Lower z-index to render behind border corners
|
|
||||||
|
|
||||||
layer.enabled: borderShape.clockWidget !== null
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: 1
|
|
||||||
verticalOffset: -1
|
|
||||||
radius: 12 // Much more subtle
|
|
||||||
samples: 25
|
|
||||||
color: Qt.rgba(0, 0, 0, 0.4) // Very light shadow
|
|
||||||
cached: false
|
|
||||||
spread: 0.2 // Minimal spread
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Shadow rendering source (hidden)
|
|
||||||
Item {
|
|
||||||
id: shadowSource
|
|
||||||
anchors.fill: parent
|
|
||||||
visible: false
|
|
||||||
|
|
||||||
Shape {
|
|
||||||
id: borderShadowShape
|
|
||||||
anchors.fill: parent
|
|
||||||
|
|
||||||
layer.enabled: true
|
|
||||||
layer.samples: 4
|
|
||||||
|
|
||||||
ShapePath {
|
|
||||||
fillColor: "black"
|
|
||||||
strokeWidth: 0
|
|
||||||
fillRule: ShapePath.OddEvenFill
|
|
||||||
|
|
||||||
// Outer rectangle (full screen)
|
|
||||||
PathMove {
|
|
||||||
x: 0
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: shadowSource.width
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: shadowSource.width
|
|
||||||
y: shadowSource.height
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: 0
|
|
||||||
y: shadowSource.height
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: 0
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
// Inner rounded cutout creates border
|
|
||||||
PathMove {
|
|
||||||
x: borderShape.innerX + borderShape.radius
|
|
||||||
y: borderShape.innerY
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth - borderShape.radius
|
|
||||||
y: borderShape.innerY
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth
|
|
||||||
y: borderShape.innerY + borderShape.radius
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight - borderShape.radius
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth - borderShape.radius
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX + borderShape.radius
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight - borderShape.radius
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX
|
|
||||||
y: borderShape.innerY + borderShape.radius
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX + borderShape.radius
|
|
||||||
y: borderShape.innerY
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Workspace indicator shadow with concave curves
|
|
||||||
Shape {
|
|
||||||
id: workspaceShadowShape
|
|
||||||
visible: borderShape.workspaceIndicator !== null
|
|
||||||
x: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.x : 0 // Exact match
|
|
||||||
y: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.y : 0
|
|
||||||
width: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.width : 0 // Exact match
|
|
||||||
height: borderShape.workspaceIndicator ? borderShape.workspaceIndicator.height : 0
|
|
||||||
preferredRendererType: Shape.CurveRenderer
|
|
||||||
|
|
||||||
layer.enabled: borderShape.workspaceIndicator !== null
|
|
||||||
layer.samples: 8
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: 2
|
|
||||||
verticalOffset: 3
|
|
||||||
radius: 25 + (effectsActive && Data.Settings.workspaceGlowEnabled ? Math.sin(masterProgress * Math.PI) * 6 : 0)
|
|
||||||
samples: 40
|
|
||||||
color: {
|
|
||||||
if (!effectsActive)
|
|
||||||
return Qt.rgba(0, 0, 0, 0.8);
|
|
||||||
if (!Data.Settings.workspaceGlowEnabled)
|
|
||||||
return Qt.rgba(0, 0, 0, 0.8);
|
|
||||||
// Accent color glow with reduced intensity
|
|
||||||
const intensity = Math.sin(masterProgress * Math.PI) * 0.3;
|
|
||||||
return Qt.rgba(effectColor.r * intensity + 0.1, effectColor.g * intensity + 0.1, effectColor.b * intensity + 0.1, 0.6 + intensity * 0.15);
|
|
||||||
}
|
|
||||||
cached: false
|
|
||||||
spread: 0.5 + (effectsActive && Data.Settings.workspaceGlowEnabled ? Math.sin(masterProgress * Math.PI) * 0.2 : 0)
|
|
||||||
}
|
|
||||||
|
|
||||||
ShapePath {
|
|
||||||
strokeWidth: 0
|
|
||||||
fillColor: "black"
|
|
||||||
strokeColor: "black"
|
|
||||||
|
|
||||||
startX: 12
|
|
||||||
startY: 0
|
|
||||||
|
|
||||||
// Right side - standard rounded corners
|
|
||||||
PathLine {
|
|
||||||
x: workspaceShadowShape.width - 16
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: workspaceShadowShape.width
|
|
||||||
y: 16
|
|
||||||
radiusX: 16
|
|
||||||
radiusY: 16
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: workspaceShadowShape.width
|
|
||||||
y: workspaceShadowShape.height - 16
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: workspaceShadowShape.width - 16
|
|
||||||
y: workspaceShadowShape.height
|
|
||||||
radiusX: 16
|
|
||||||
radiusY: 16
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: 12
|
|
||||||
y: workspaceShadowShape.height
|
|
||||||
}
|
|
||||||
|
|
||||||
// Left side - concave curves for border integration
|
|
||||||
PathLine {
|
|
||||||
x: 0
|
|
||||||
y: workspaceShadowShape.height - 12
|
|
||||||
}
|
|
||||||
PathArc {
|
|
||||||
x: 12
|
|
||||||
y: workspaceShadowShape.height - 24
|
|
||||||
radiusX: 12
|
|
||||||
radiusY: 12
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: 12
|
|
||||||
y: 24
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: 0
|
|
||||||
y: 12
|
|
||||||
radiusX: 12
|
|
||||||
radiusY: 12
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: 12
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Volume OSD shadow
|
|
||||||
Rectangle {
|
|
||||||
id: volumeOsdShadowShape
|
|
||||||
visible: borderShape.volumeOSD !== null && borderShape.volumeOSD.visible
|
|
||||||
x: shadowSource.width - 45
|
|
||||||
y: (shadowSource.height - 250) / 2
|
|
||||||
width: 45
|
|
||||||
height: 250
|
|
||||||
color: "black"
|
|
||||||
topLeftRadius: 20
|
|
||||||
bottomLeftRadius: 20
|
|
||||||
topRightRadius: 0
|
|
||||||
bottomRightRadius: 0
|
|
||||||
|
|
||||||
layer.enabled: borderShape.volumeOSD !== null && borderShape.volumeOSD.visible
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: -2 // Shadow to the left for right-side widget
|
|
||||||
verticalOffset: 3
|
|
||||||
radius: 25
|
|
||||||
samples: 40
|
|
||||||
color: Qt.rgba(0, 0, 0, 0.8)
|
|
||||||
cached: false
|
|
||||||
spread: 0.5
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Clock shadow
|
|
||||||
Rectangle {
|
|
||||||
id: clockShadowShape
|
|
||||||
visible: borderShape.clockWidget !== null
|
|
||||||
x: borderShape.clockWidget ? borderShape.clockWidget.x : 0
|
|
||||||
y: borderShape.clockWidget ? borderShape.clockWidget.y : 0
|
|
||||||
width: borderShape.clockWidget ? borderShape.clockWidget.width : 0
|
|
||||||
height: borderShape.clockWidget ? borderShape.clockWidget.height : 0
|
|
||||||
color: "black"
|
|
||||||
topLeftRadius: 0
|
|
||||||
topRightRadius: borderShape.clockWidget ? borderShape.clockWidget.height / 2 : 16
|
|
||||||
bottomLeftRadius: 0
|
|
||||||
bottomRightRadius: 0
|
|
||||||
|
|
||||||
layer.enabled: borderShape.clockWidget !== null
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: 2
|
|
||||||
verticalOffset: -2 // Shadow upward for bottom widget
|
|
||||||
radius: 25
|
|
||||||
samples: 40
|
|
||||||
color: Qt.rgba(0, 0, 0, 0.8)
|
|
||||||
cached: false
|
|
||||||
spread: 0.5
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Apply shadow effect to entire border shape
|
|
||||||
layer.enabled: true
|
|
||||||
layer.samples: 8
|
|
||||||
layer.smooth: true
|
|
||||||
layer.effect: DropShadow {
|
|
||||||
transparentBorder: true
|
|
||||||
horizontalOffset: 1
|
|
||||||
verticalOffset: 2
|
|
||||||
radius: 30 // Slightly less dramatic
|
|
||||||
samples: 45
|
|
||||||
color: Qt.rgba(0, 0, 0, 0.75) // A bit lighter
|
|
||||||
cached: false
|
|
||||||
spread: 0.5 // Less spread
|
|
||||||
}
|
|
||||||
|
|
||||||
// Main border shape
|
|
||||||
ShapePath {
|
|
||||||
fillColor: Data.ThemeManager.bgColor
|
|
||||||
strokeWidth: 0
|
|
||||||
fillRule: ShapePath.OddEvenFill
|
|
||||||
|
|
||||||
// Outer rectangle
|
|
||||||
PathMove {
|
|
||||||
x: 0
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.width
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.width
|
|
||||||
y: borderShape.height
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: 0
|
|
||||||
y: borderShape.height
|
|
||||||
}
|
|
||||||
PathLine {
|
|
||||||
x: 0
|
|
||||||
y: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
// Inner rounded cutout
|
|
||||||
PathMove {
|
|
||||||
x: borderShape.innerX + borderShape.radius
|
|
||||||
y: borderShape.innerY
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth - borderShape.radius
|
|
||||||
y: borderShape.innerY
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth
|
|
||||||
y: borderShape.innerY + borderShape.radius
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight - borderShape.radius
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX + borderShape.innerWidth - borderShape.radius
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX + borderShape.radius
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX
|
|
||||||
y: borderShape.innerY + borderShape.innerHeight - borderShape.radius
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
|
|
||||||
PathLine {
|
|
||||||
x: borderShape.innerX
|
|
||||||
y: borderShape.innerY + borderShape.radius
|
|
||||||
}
|
|
||||||
|
|
||||||
PathArc {
|
|
||||||
x: borderShape.innerX + borderShape.radius
|
|
||||||
y: borderShape.innerY
|
|
||||||
radiusX: borderShape.radius
|
|
||||||
radiusY: borderShape.radius
|
|
||||||
direction: PathArc.Clockwise
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user