all the work to make stylix work again, just need to update the flake lock when it's time

This commit is contained in:
Lillian Violet 2025-04-01 17:26:15 +02:00
parent 480bdcdcc4
commit e4839e4d2e
6 changed files with 114 additions and 317 deletions

View file

@ -131,7 +131,7 @@
nix-index-database.nixosModules.nix-index nix-index-database.nixosModules.nix-index
{ {
home-manager.sharedModules = [ home-manager.sharedModules = [
inputs.catppuccin.homeManagerModules.catppuccin inputs.catppuccin.homeModules.catppuccin
./home-manager/shared ./home-manager/shared
sops-nix.homeManagerModules.sops sops-nix.homeManagerModules.sops
]; ];
@ -164,7 +164,7 @@
nixosModules = import ./modules/nixos; nixosModules = import ./modules/nixos;
# Reusable home-manager modules you might want to export # Reusable home-manager modules you might want to export
# These are usually stuff you would upstream into home-manager # These are usually stuff you would upstream into home-manager
homeManagerModules = import ./modules/home-manager; # homeManagerModules = import ./modules/home-manager;
# Your custom packages and modifications, exported as overlays # Your custom packages and modifications, exported as overlays
overlays = import ./overlays {inherit inputs;}; overlays = import ./overlays {inherit inputs;};

View file

@ -4,6 +4,7 @@
# catppuccin.enable = true; # catppuccin.enable = true;
settings = { settings = {
main = { main = {
font = "Atkinson Monolegible:size=12";
}; };
mouse = { mouse = {

View file

@ -13,33 +13,33 @@
programs.plasma = { programs.plasma = {
enable = true; enable = true;
desktop.mouseActions.verticalScroll = "switchVirtualDesktop"; desktop.mouseActions.verticalScroll = "switchVirtualDesktop";
# kscreenlocker.appearance.wallpaper = "${osConfig.stylix.image}"; kscreenlocker.appearance.wallpaper = "${osConfig.stylix.image}";
# fonts = { fonts = {
# fixedWidth = { fixedWidth = {
# pointSize = 11; pointSize = 11;
# family = "${osConfig.stylix.fonts.monospace.name}"; family = "${osConfig.stylix.fonts.monospace.name}";
# }; };
# general = { general = {
# pointSize = 11; pointSize = 11;
# family = "${osConfig.stylix.fonts.serif.name}"; family = "${osConfig.stylix.fonts.serif.name}";
# }; };
# menu = { menu = {
# pointSize = 11; pointSize = 11;
# family = "${osConfig.stylix.fonts.sansSerif.name}"; family = "${osConfig.stylix.fonts.sansSerif.name}";
# }; };
# small = { small = {
# pointSize = 11; pointSize = 11;
# family = "${osConfig.stylix.fonts.sansSerif.name}"; family = "${osConfig.stylix.fonts.sansSerif.name}";
# }; };
# toolbar = { toolbar = {
# pointSize = 11; pointSize = 11;
# family = "${osConfig.stylix.fonts.sansSerif.name}"; family = "${osConfig.stylix.fonts.sansSerif.name}";
# }; };
# windowTitle = { windowTitle = {
# pointSize = 11; pointSize = 11;
# family = "${osConfig.stylix.fonts.sansSerif.name}"; family = "${osConfig.stylix.fonts.sansSerif.name}";
# }; };
# }; };
panels = [ panels = [
{ {
alignment = "left"; alignment = "left";
@ -82,6 +82,7 @@
"qBittorrent" "qBittorrent"
"vlc" "vlc"
"steam" "steam"
"Thunderbird Daily"
]; ];
}; };
} }

View file

@ -54,36 +54,33 @@
# }; # };
}; };
}; };
# stylix.enable = true;
# qt.platformTheme.name = lib.mkForce "kvantum";
# qt.style.name = lib.mkForce "kvantum";
# stylix = { stylix = {
# enable = true; enable = true;
# autoEnable = true; autoEnable = true;
# base16Scheme = { base16Scheme = {
# scheme = "Catppuccin Macchiato"; scheme = "Catppuccin Macchiato";
# author = "https://github.com/catppuccin/catppuccin"; author = "https://github.com/catppuccin/catppuccin";
# base00 = "24273a"; base00 = "24273a";
# base01 = "1e2030"; base01 = "1e2030";
# base02 = "363a4f"; base02 = "363a4f";
# base03 = "494d64"; base03 = "494d64";
# base04 = "5b6078"; base04 = "5b6078";
# base05 = "cad3f5"; base05 = "cad3f5";
# base06 = "f4dbd6"; base06 = "f4dbd6";
# base07 = "b7bdf8"; base07 = "b7bdf8";
# base08 = "ed8796"; base08 = "ed8796";
# base09 = "f5a97f"; base09 = "f5a97f";
# base0A = "eed49f"; base0A = "eed49f";
# base0B = "a6da95"; base0B = "a6da95";
# base0C = "8bd5ca"; base0C = "8bd5ca";
# base0D = "8aadf4"; base0D = "8aadf4";
# base0E = "c6a0f6"; base0E = "c6a0f6";
# base0F = "f0c6c6"; base0F = "f0c6c6";
# }; };
# image = ./background.jpg; image = ./background.jpg;
# cursor.package = pkgs.catppuccin-cursors; cursor.package = pkgs.catppuccin-cursors;
# cursor.name = "catppuccin-macchiato-mauve-cursors"; cursor.name = "catppuccin-macchiato-mauve-cursors";
# cursor.size = 16; cursor.size = 16;
# }; };
} }

View file

@ -70,8 +70,8 @@
catppuccin = { catppuccin = {
flavor = "macchiato"; flavor = "macchiato";
tty.enable = true; tty.enable = true;
# sddm.enable = true; sddm.enable = true;
# sddm.flavor = "macchiato"; sddm.flavor = "macchiato";
forgejo.enable = true; forgejo.enable = true;
forgejo.flavor = "macchiato"; forgejo.flavor = "macchiato";
# plymouth.enable = false; # plymouth.enable = false;
@ -87,70 +87,70 @@
enableBrowserSocket = true; enableBrowserSocket = true;
}; };
# stylix = { stylix = {
# enable = true; enable = true;
# # targets.qt.platform = "kde6"; autoEnable = true;
# autoEnable = true; base16Scheme = {
# base16Scheme = { scheme = "Catppuccin Macchiato";
# scheme = "Catppuccin Macchiato"; author = "https://github.com/catppuccin/catppuccin";
# author = "https://github.com/catppuccin/catppuccin"; base00 = "24273a";
# base00 = "24273a"; base01 = "1e2030";
# base01 = "1e2030"; base02 = "363a4f";
# base02 = "363a4f"; base03 = "494d64";
# base03 = "494d64"; base04 = "5b6078";
# base04 = "5b6078"; base05 = "cad3f5";
# base05 = "cad3f5"; base06 = "f4dbd6";
# base06 = "f4dbd6"; base07 = "b7bdf8";
# base07 = "b7bdf8"; base08 = "ed8796";
# base08 = "ed8796"; base09 = "f5a97f";
# base09 = "f5a97f"; base0A = "eed49f";
# base0A = "eed49f"; base0B = "a6da95";
# base0B = "a6da95"; base0C = "8bd5ca";
# base0C = "8bd5ca"; base0D = "8aadf4";
# base0D = "8aadf4"; base0E = "c6a0f6";
# base0E = "c6a0f6"; base0F = "f0c6c6";
# base0F = "f0c6c6"; };
# }; image = ./background.jpg;
# image = ./background.jpg; cursor.package = pkgs.catppuccin-cursors.macchiatoMauve;
# cursor.package = pkgs.catppuccin-cursors.macchiatoMauve; cursor.name = "catppuccin-macchiato-mauve-cursors";
# cursor.name = "catppuccin-macchiato-mauve-cursors"; cursor.size = 16;
# cursor.size = 16; homeManagerIntegration.followSystem = true;
# homeManagerIntegration.followSystem = true; fonts = {
# fonts = { serif = {
# serif = { package = pkgs.atkinson-hyperlegible;
# package = pkgs.dejavu_fonts; name = "Atkinson Hyperlegible";
# name = "DejaVu Serif"; };
# };
# monospace = { monospace = {
# package = pkgs.dejavu_fonts; package = pkgs.atkinson-monolegible;
# name = "DejaVu Sans Mono"; name = "Atkinson Monolegible";
# }; };
# sansSerif = { sansSerif = {
# package = pkgs.dejavu_fonts; package = pkgs.atkinson-hyperlegible;
# name = "DejaVu Sans"; name = "Atkinson Hyperlegible";
# }; };
# emoji = { emoji = {
# package = pkgs.noto-fonts-emoji-blob-bin; package = pkgs.noto-fonts-emoji-blob-bin;
# name = "Blobmoji"; name = "Blobmoji";
# }; };
# }; };
# }; };
fonts.packages = [ fonts.packages = [
pkgs.atkinson-hyperlegible pkgs.atkinson-hyperlegible
pkgs.atkinson-monolegible pkgs.atkinson-monolegible
pkgs.noto-fonts-emoji-blob-bin
pkgs.noto-fonts pkgs.noto-fonts
pkgs.nerd-fonts.fira-mono pkgs.nerd-fonts.fira-mono
]; ];
fonts.fontconfig.defaultFonts = { # fonts.fontconfig.defaultFonts = {
emoji = ["Blobmoji"]; # emoji = ["Blobmoji"];
monospace = ["Atkinson Monolegible"]; # monospace = ["Atkinson Monolegible"];
sansSerif = ["Atkinson Hyperlegible"]; # sansSerif = ["Atkinson Hyperlegible"];
}; # };
networking = networking =
if config.services.vpn-ip.enable if config.services.vpn-ip.enable

View file

@ -1,202 +0,0 @@
{
lib,
buildNpmPackage,
cargo,
copyDesktopItems,
dbus,
electron_28,
fetchFromGitLab,
glib,
gnome,
gtk3,
jq,
libsecret,
makeDesktopItem,
makeWrapper,
moreutils,
napi-rs-cli,
nodejs_18,
patchutils_0_4_2,
pkg-config,
python3,
runCommand,
rustc,
rustPlatform,
}: let
description = "A secure and free password manager for all of your devices";
icon = "bitwarden";
electron = electron_28;
in
buildNpmPackage rec {
pname = "bitwarden-desktop";
version = "2024.3.0";
src = fetchFromGitLab {
owner = "videostreaming";
repo = "fcast";
rev = "b13d0f7e8150c279d377a78f89d338b7fc0f5539";
hash = "sha256-XEZB95GnfSy/wtTWpF8KlUQwyephUZmSLtbOwbcvd7g=";
};
patches = [
./electron-builder-package-lock.patch
];
# The nested package-lock.json from upstream is out-of-date, so copy the
# lock metadata from the root package-lock.json.
postPatch = ''
cat {,apps/desktop/src/}package-lock.json \
| ${lib.getExe jq} -s '
.[1].packages."".dependencies.argon2 = .[0].packages."".dependencies.argon2
| .[0].packages."" = .[1].packages.""
| .[1].packages = .[0].packages
| .[1]
' \
| ${moreutils}/bin/sponge apps/desktop/src/package-lock.json
'';
nodejs = nodejs_18;
makeCacheWritable = true;
npmFlags = ["--legacy-peer-deps"];
npmWorkspace = "apps/desktop";
npmDepsHash = "sha256-EpZXA+GkmHl5eqwIPTGHJZqrpr6k8gXneJG+GXumlkc=";
cargoDeps = rustPlatform.fetchCargoTarball {
name = "${pname}-${version}";
inherit src;
patches =
map
(
patch:
runCommand
(builtins.baseNameOf patch)
{nativeBuildInputs = [patchutils_0_4_2];}
''
< ${patch} filterdiff -p1 --include=${lib.escapeShellArg cargoRoot}'/*' > $out
''
)
patches;
patchFlags = ["-p4"];
sourceRoot = "${src.name}/${cargoRoot}";
hash = "sha256-qAqEFlUzT28fw6kLB8d7U8yXWevAU+q03zjN2xWsGyI=";
};
cargoRoot = "apps/desktop/desktop_native";
env.ELECTRON_SKIP_BINARY_DOWNLOAD = "1";
nativeBuildInputs = [
cargo
copyDesktopItems
jq
makeWrapper
moreutils
napi-rs-cli
pkg-config
python3
rustc
rustPlatform.cargoCheckHook
rustPlatform.cargoSetupHook
];
buildInputs = [
glib
gtk3
libsecret
];
preBuild = ''
if [[ $(jq --raw-output '.devDependencies.electron' < package.json | grep -E --only-matching '^[0-9]+') != ${lib.escapeShellArg (lib.versions.major electron.version)} ]]; then
echo 'ERROR: electron version mismatch'
exit 1
fi
'';
postBuild = ''
pushd apps/desktop
# desktop_native/index.js loads a file of that name regarldess of the libc being used
mv desktop_native/desktop_native.* desktop_native/desktop_native.linux-x64-musl.node
npm exec electron-builder -- \
--dir \
-c.electronDist=${electron}/libexec/electron \
-c.electronVersion=${electron.version}
popd
'';
doCheck = true;
nativeCheckInputs = [
dbus
(gnome.gnome-keyring.override {useWrappedDaemon = false;})
];
checkFlags = [
"--skip=password::password::tests::test"
];
checkPhase = ''
runHook preCheck
pushd ${cargoRoot}
export HOME=$(mktemp -d)
export -f cargoCheckHook runHook _eval _callImplicitHook
export cargoCheckType=release
dbus-run-session \
--config-file=${dbus}/share/dbus-1/session.conf \
-- bash -e -c cargoCheckHook
popd
runHook postCheck
'';
installPhase = ''
runHook preInstall
mkdir $out
pushd apps/desktop/dist/linux-unpacked
mkdir -p $out/opt/Bitwarden
cp -r locales resources{,.pak} $out/opt/Bitwarden
popd
makeWrapper '${electron}/bin/electron' "$out/bin/bitwarden" \
--add-flags $out/opt/Bitwarden/resources/app.asar \
--add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations}}" \
--set-default ELECTRON_IS_DEV 0 \
--inherit-argv0
pushd apps/desktop/resources/icons
for icon in *.png; do
dir=$out/share/icons/hicolor/"''${icon%.png}"/apps
mkdir -p "$dir"
cp "$icon" "$dir"/${icon}.png
done
popd
runHook postInstall
'';
desktopItems = [
(makeDesktopItem {
name = "bitwarden";
exec = "bitwarden %U";
inherit icon;
comment = description;
desktopName = "Bitwarden";
categories = ["Utility"];
})
];
meta = {
changelog = "https://github.com/bitwarden/clients/releases/tag/${src.rev}";
inherit description;
homepage = "https://bitwarden.com";
license = lib.licenses.gpl3;
maintainers = with lib.maintainers; [amarshall kiwi];
platforms = ["x86_64-linux"];
mainProgram = "bitwarden";
};
}