Compare commits
4 commits
d76b16ddc7
...
d6cb176357
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d6cb176357 | ||
|
|
a66ba69b61 | ||
|
|
fc1075fc52 | ||
|
|
7a7e3d56b2 |
7 changed files with 51 additions and 25 deletions
|
|
@ -14,7 +14,6 @@ let
|
|||
];
|
||||
|
||||
gnomePkgs = with pkgs; [
|
||||
gnomecast
|
||||
gnome-tweaks
|
||||
gnomeExtensions.worksets
|
||||
];
|
||||
|
|
@ -23,11 +22,9 @@ in
|
|||
imports = [
|
||||
(import ./commandline.nix)
|
||||
(import ./programs/alacritty)
|
||||
# (import ./programs/kitty)
|
||||
# (import ./programs/wezterm)
|
||||
];
|
||||
|
||||
nixpkgs.overlays = [ (import ../overlays/paperwm.nix) ];
|
||||
nixpkgs.overlays = [];
|
||||
|
||||
home = {
|
||||
packages = defaultPkgs ++ gnomePkgs;
|
||||
|
|
|
|||
|
|
@ -1,4 +1,8 @@
|
|||
{ pkgs, ... }:
|
||||
{ pkgs, ...}:
|
||||
let
|
||||
# We need a version of vscode-language-servers that's less than 4.10
|
||||
oldNixpkgs = import (fetchTarball "https://github.com/NixOS/nixpkgs/archive/f68797befe20fc56153363e71ea0f0b74542db4b.tar.gz") {};
|
||||
in
|
||||
{
|
||||
programs.helix = {
|
||||
enable = true;
|
||||
|
|
@ -9,10 +13,29 @@
|
|||
};
|
||||
|
||||
typescript-language-server = {
|
||||
command = "typescript-language-server";
|
||||
command = "${pkgs.typescript-language-server}/bin/typescript-language-server";
|
||||
args = [ "--stdio" ];
|
||||
config.hostInfo = "helix";
|
||||
};
|
||||
|
||||
eslint = {
|
||||
command = "${oldNixpkgs.nodePackages.vscode-langservers-extracted}/bin/vscode-eslint-language-server";
|
||||
args = ["--stdio"];
|
||||
config = {
|
||||
run = "onType";
|
||||
validate = "on";
|
||||
nodePath = "";
|
||||
rulesCustomizations = [];
|
||||
workingDirectory.mode = "location";
|
||||
showDocumentation.enable = true;
|
||||
experimental = { useFlatConfig = false; };
|
||||
problems = { shortenToSingleLine = false; };
|
||||
codeAction = {
|
||||
enable = true;
|
||||
location = "separateLine";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
language = [
|
||||
|
|
@ -25,11 +48,13 @@
|
|||
}
|
||||
{
|
||||
name = "typescript";
|
||||
file-types = [ "tsx" "ts" ];
|
||||
auto-format = true;
|
||||
formatter = { command = "prettier"; args = ["--parser=typescript"]; };
|
||||
language-servers = [
|
||||
{ name = "eslint"; }
|
||||
{
|
||||
name = "typescript-language-server";
|
||||
except-features = [ "format" "diagnostics" ];
|
||||
}
|
||||
];
|
||||
}
|
||||
|
|
@ -45,6 +70,7 @@
|
|||
normal = "block";
|
||||
select = "block";
|
||||
};
|
||||
bufferline = "multiple";
|
||||
};
|
||||
keys = {
|
||||
normal = {
|
||||
|
|
@ -52,7 +78,6 @@
|
|||
"ret" = [ "move_line_down" "goto_first_nonwhitespace" ]; # Maps the enter key to move to start of next line
|
||||
X = "extend_line_above";
|
||||
D = "delete_char_backward";
|
||||
";" = "command_mode"; # Note: this shadows the normal use of ";", which is to reset the selection to the cursor.
|
||||
"S-ret" = [ "move_line_up" "goto_first_nonwhitespace" ];
|
||||
};
|
||||
insert = {
|
||||
|
|
|
|||
|
|
@ -124,12 +124,13 @@ with builtins;
|
|||
config = ''
|
||||
lua << EOF
|
||||
${readFile (
|
||||
pkgs.substituteAll {
|
||||
src = ./nvim-lspconfig.lua;
|
||||
pkgs.replaceVars ./nvim-lspconfig.lua {
|
||||
# since both of these are used for actually configuring the system,
|
||||
# we'll probably always want them around.
|
||||
lua_ls = pkgs.sumneko-lua-language-server;
|
||||
nixd = pkgs.nixd;
|
||||
ts_server = pkgs.nodePackages.typescript-language-server;
|
||||
diagnostic_server = pkgs.nodePackages.diagnostic-languageserver;
|
||||
}
|
||||
) }
|
||||
EOF
|
||||
|
|
|
|||
|
|
@ -62,6 +62,7 @@ vim.api.nvim_create_autocmd("BufWritePre", {
|
|||
})
|
||||
|
||||
nvim_lsp.diagnosticls.setup {
|
||||
cmd = { "@diagnostic_server@/bin/diagnostic-languageserver", '--stdio' },
|
||||
filetypes = { 'javascript', 'javascriptreact', 'typescript', 'typescriptreact', 'css', 'scss', 'markdown', 'pandoc',
|
||||
'prisma' },
|
||||
init_options = {
|
||||
|
|
@ -150,6 +151,7 @@ capabilitiesWithoutFomatting.textDocument.rangeFormatting = false
|
|||
capabilitiesWithoutFomatting.textDocument.range_formatting = false
|
||||
|
||||
nvim_lsp.ts_ls.setup {
|
||||
cmd = { "@ts_server@/bin/typescript-language-server", '--stdio' },
|
||||
init_options = {
|
||||
hostInfo = "neovim",
|
||||
maxTsServerMemory = "8192",
|
||||
|
|
|
|||
|
|
@ -1,12 +0,0 @@
|
|||
# Keep until https://github.com/paperwm/PaperWM/issues/376 is fixed
|
||||
self: super: {
|
||||
gnomeExtensions = super.gnomeExtensions // {
|
||||
paperwm = super.gnomeExtensions.paperwm.overrideDerivation (old: {
|
||||
version = "pre-40.0";
|
||||
src = builtins.fetchGit {
|
||||
url = https://github.com/paperwm/paperwm.git;
|
||||
ref = "next-release";
|
||||
};
|
||||
});
|
||||
};
|
||||
}
|
||||
|
|
@ -69,6 +69,7 @@
|
|||
environment.systemPackages = with pkgs; [
|
||||
cachix
|
||||
colmena
|
||||
gnomeExtensions.paperwm
|
||||
vim
|
||||
wget
|
||||
zsh
|
||||
|
|
@ -102,6 +103,18 @@
|
|||
# List services that you want to enable:
|
||||
services.dbus.packages = with pkgs; [ dconf ];
|
||||
|
||||
### Set dconf to enable PaperWM out of the box
|
||||
programs.dconf =
|
||||
{ enable = true;
|
||||
profiles."user".databases = [
|
||||
{ settings =
|
||||
{ "org/gnome/shell" =
|
||||
{ enabled-extensions = [ "paperwm@paperwm.github.com" ];
|
||||
};
|
||||
};
|
||||
}
|
||||
];
|
||||
};
|
||||
|
||||
# Enable the OpenSSH daemon.
|
||||
# services.openssh.enable = true;
|
||||
|
|
@ -122,7 +135,7 @@
|
|||
networking.wireguard.enable = true;
|
||||
|
||||
services.pipewire = {
|
||||
enable = false;
|
||||
enable = true;
|
||||
alsa.enable = true;
|
||||
jack.enable = true;
|
||||
pulse.enable = true;
|
||||
|
|
|
|||
|
|
@ -104,14 +104,14 @@ in
|
|||
../../home/programs/alacritty
|
||||
];
|
||||
|
||||
# Auto upgrade nix package and the daemon service.
|
||||
services.nix-daemon.enable = true;
|
||||
# nix.package = pkgs.nix;
|
||||
|
||||
# Create /etc/bashrc that loads the nix-darwin environment.
|
||||
programs.zsh.enable = true; # default shell on catalina
|
||||
# programs.fish.enable = true;
|
||||
|
||||
system.primaryUser = "haak";
|
||||
|
||||
# We need this snippet to allow spotlight to find the applications installed
|
||||
# by nix-darwin
|
||||
system.activationScripts.applications.text = pkgs.lib.mkForce (
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue