refactor: desktop default applications
This commit is contained in:
@@ -1,20 +1,44 @@
|
||||
{ config, ... }:
|
||||
{ ... }:
|
||||
let
|
||||
repo = config.repo;
|
||||
mkPrimaryDesktopApplication =
|
||||
{
|
||||
name,
|
||||
package,
|
||||
desktopEntryName,
|
||||
}:
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
meta.desktop.${name} = {
|
||||
inherit desktopEntryName;
|
||||
package = package pkgs;
|
||||
};
|
||||
};
|
||||
in
|
||||
{
|
||||
flake.modules.homeManager.primary-browser-vivaldi = mkPrimaryDesktopApplication {
|
||||
name = "browser";
|
||||
package = pkgs: pkgs.vivaldi;
|
||||
desktopEntryName = "vivaldi-stable";
|
||||
};
|
||||
|
||||
flake.modules.homeManager.primary-file-manager-nautilus = mkPrimaryDesktopApplication {
|
||||
name = "fileManager";
|
||||
package = pkgs: pkgs.nautilus;
|
||||
desktopEntryName = "org.gnome.Nautilus";
|
||||
};
|
||||
|
||||
flake.modules.homeManager.desktop-defaults =
|
||||
{ config, pkgs, ... }:
|
||||
let
|
||||
browserPackage = pkgs.${repo.desktop.browser.packageAttr};
|
||||
fileManagerPackage = pkgs.${repo.desktop.fileManager.packageAttr};
|
||||
browser = config.meta.desktop.browser;
|
||||
fileManager = config.meta.desktop.fileManager;
|
||||
homeDir = config.home.homeDirectory;
|
||||
localDir = "${homeDir}/.local";
|
||||
mediaDir = "${homeDir}/media";
|
||||
in
|
||||
{
|
||||
home.preferXdgDirectories = true;
|
||||
home.sessionVariables.BROWSER = repo.desktop.browser.command;
|
||||
home.sessionVariables.BROWSER = browser.command;
|
||||
|
||||
home.packages =
|
||||
with pkgs;
|
||||
@@ -28,8 +52,8 @@ in
|
||||
dbeaver-bin
|
||||
]
|
||||
++ [
|
||||
browserPackage
|
||||
fileManagerPackage
|
||||
browser.package
|
||||
fileManager.package
|
||||
];
|
||||
|
||||
programs.imv.enable = true;
|
||||
@@ -69,8 +93,8 @@ in
|
||||
neovim
|
||||
]
|
||||
++ [
|
||||
browserPackage
|
||||
fileManagerPackage
|
||||
fileManager.package
|
||||
browser.package
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
@@ -1,15 +1,23 @@
|
||||
{ config, ... }:
|
||||
let
|
||||
nixosModules = config.flake.modules.nixos;
|
||||
in
|
||||
{
|
||||
flake.modules.nixos.server-firewall = {
|
||||
networking = {
|
||||
firewall.enable = true;
|
||||
firewall.allowPing = false;
|
||||
};
|
||||
flake.modules.nixos.nftables-firewall = {
|
||||
networking.nftables.enable = true;
|
||||
};
|
||||
|
||||
flake.modules.nixos.network-manager = {
|
||||
networking = {
|
||||
nftables.enable = true;
|
||||
networkmanager.enable = true;
|
||||
};
|
||||
networking.networkmanager.enable = true;
|
||||
};
|
||||
|
||||
flake.modules.nixos.server-firewall =
|
||||
{ ... }:
|
||||
{
|
||||
imports = [
|
||||
nixosModules.nftables-firewall
|
||||
];
|
||||
|
||||
networking.firewall.allowPing = false;
|
||||
};
|
||||
}
|
||||
|
||||
@@ -32,9 +32,9 @@ in
|
||||
}:
|
||||
let
|
||||
repoTheme = repo.theme.kanagawa;
|
||||
browserCommand = repo.desktop.browser.command;
|
||||
fileManagerPackage = pkgs.${repo.desktop.fileManager.packageAttr};
|
||||
terminalCommand = config.repo.terminal.primary.command;
|
||||
browserCommand = config.meta.desktop.browser.command;
|
||||
fileManagerPackage = config.meta.desktop.fileManager.package;
|
||||
terminalCommand = config.meta.desktop.terminal.command;
|
||||
outputs = lib.mapAttrs (
|
||||
_: display:
|
||||
{
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
{
|
||||
homeDirectory,
|
||||
lib,
|
||||
terminal,
|
||||
terminalCommand,
|
||||
}:
|
||||
{
|
||||
settingsVersion = 53;
|
||||
@@ -260,7 +260,7 @@
|
||||
pinnedApps = [ ];
|
||||
useApp2Unit = false;
|
||||
sortByMostUsed = true;
|
||||
terminalCommand = lib.concatStringsSep " " ([ terminal.command ] ++ terminal.execArgs);
|
||||
inherit terminalCommand;
|
||||
customLaunchPrefixEnabled = false;
|
||||
customLaunchPrefix = "";
|
||||
viewMode = "grid";
|
||||
|
||||
@@ -8,13 +8,13 @@ let
|
||||
{
|
||||
homeDirectory,
|
||||
lib,
|
||||
terminal,
|
||||
terminalCommand,
|
||||
}:
|
||||
import ./_noctalia-config.nix {
|
||||
inherit
|
||||
homeDirectory
|
||||
lib
|
||||
terminal
|
||||
terminalCommand
|
||||
;
|
||||
};
|
||||
|
||||
@@ -22,13 +22,13 @@ let
|
||||
{
|
||||
homeDirectory,
|
||||
lib,
|
||||
terminal,
|
||||
terminalCommand,
|
||||
}:
|
||||
mkNoctaliaSettings {
|
||||
inherit
|
||||
homeDirectory
|
||||
lib
|
||||
terminal
|
||||
terminalCommand
|
||||
;
|
||||
};
|
||||
|
||||
@@ -68,7 +68,7 @@ in
|
||||
baseSettings = mkBaseSettings {
|
||||
inherit lib;
|
||||
homeDirectory = config.home.homeDirectory;
|
||||
terminal = config.repo.terminal.primary;
|
||||
terminalCommand = lib.getExe pkgs.xdg-terminal-exec;
|
||||
};
|
||||
settings =
|
||||
if baseSettings == { } || !osConfig.meta.machine.portable then
|
||||
|
||||
@@ -5,20 +5,31 @@
|
||||
let
|
||||
repo = config.repo;
|
||||
account = repo.account;
|
||||
homeModules = config.flake.modules.homeManager;
|
||||
in
|
||||
{
|
||||
flake.modules.homeManager.pinentry =
|
||||
{ pkgs, ... }:
|
||||
{
|
||||
meta.pinentry.package = pkgs.pinentry-gnome3;
|
||||
};
|
||||
|
||||
flake.modules.homeManager.passwords =
|
||||
{
|
||||
pkgs,
|
||||
config,
|
||||
...
|
||||
}:
|
||||
{
|
||||
imports = [
|
||||
homeModules.pinentry
|
||||
];
|
||||
|
||||
programs.rbw = {
|
||||
enable = true;
|
||||
settings = {
|
||||
base_url = repo.services.vaultwarden.url;
|
||||
email = account.primaryEmail.address;
|
||||
pinentry = pkgs.pinentry-gnome3;
|
||||
pinentry = config.meta.pinentry.package;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
@@ -2,13 +2,13 @@
|
||||
let
|
||||
repo = config.repo;
|
||||
|
||||
mkPrimaryTerminal =
|
||||
mkTerminal =
|
||||
{
|
||||
desktopId,
|
||||
desktopEntryName,
|
||||
packageFor,
|
||||
terminalModule,
|
||||
}:
|
||||
{ lib, pkgs, ... }:
|
||||
{ config, pkgs, ... }:
|
||||
let
|
||||
package = packageFor pkgs;
|
||||
in
|
||||
@@ -16,18 +16,13 @@ let
|
||||
imports = [ terminalModule ];
|
||||
|
||||
config = {
|
||||
repo.terminal.primary = {
|
||||
inherit
|
||||
desktopId
|
||||
package
|
||||
;
|
||||
command = lib.getExe package;
|
||||
execArgs = [ "-e" ];
|
||||
meta.desktop.terminal = {
|
||||
inherit desktopEntryName package;
|
||||
};
|
||||
|
||||
xdg.terminal-exec = {
|
||||
enable = true;
|
||||
settings.default = [ desktopId ];
|
||||
settings.default = [ config.meta.desktop.terminal.desktopId ];
|
||||
};
|
||||
};
|
||||
};
|
||||
@@ -155,14 +150,14 @@ in
|
||||
};
|
||||
};
|
||||
|
||||
flake.modules.homeManager.primary-terminal-foot = mkPrimaryTerminal {
|
||||
desktopId = "foot.desktop";
|
||||
flake.modules.homeManager.primary-terminal-foot = mkTerminal {
|
||||
desktopEntryName = "foot";
|
||||
packageFor = pkgs: pkgs.foot;
|
||||
terminalModule = config.flake.modules.homeManager.terminal-foot;
|
||||
};
|
||||
|
||||
flake.modules.homeManager.primary-terminal-kitty = mkPrimaryTerminal {
|
||||
desktopId = "kitty.desktop";
|
||||
flake.modules.homeManager.primary-terminal-kitty = mkTerminal {
|
||||
desktopEntryName = "kitty";
|
||||
packageFor = pkgs: pkgs.kitty;
|
||||
terminalModule = config.flake.modules.homeManager.terminal-kitty;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user