mirror of
https://github.com/NotAShelf/nvf.git
synced 2026-05-19 05:24:22 +00:00
languages/react: init/split off
This commit is contained in:
parent
cd45295f9c
commit
b71d4b3800
6 changed files with 199 additions and 39 deletions
|
|
@ -108,6 +108,7 @@ isMaximal: {
|
||||||
jinja.enable = false;
|
jinja.enable = false;
|
||||||
svelte.enable = false;
|
svelte.enable = false;
|
||||||
vue.enable = false;
|
vue.enable = false;
|
||||||
|
tsx.enable = false;
|
||||||
liquid.enable = false;
|
liquid.enable = false;
|
||||||
tera.enable = false;
|
tera.enable = false;
|
||||||
twig.enable = false;
|
twig.enable = false;
|
||||||
|
|
|
||||||
|
|
@ -118,6 +118,10 @@
|
||||||
SCSS/SASS. This also changes the default LSP to `some-sass-language-server`
|
SCSS/SASS. This also changes the default LSP to `some-sass-language-server`
|
||||||
for SCSS/SASS.
|
for SCSS/SASS.
|
||||||
|
|
||||||
|
- Split React/TSX from `languages.typescript` into `languages.tsx`. This new
|
||||||
|
module provides jsx/tsx support. This is a step of cleaning up the Typescript
|
||||||
|
module for the future.
|
||||||
|
|
||||||
[CaueAnjos](https://github.com/caueanjos)
|
[CaueAnjos](https://github.com/caueanjos)
|
||||||
|
|
||||||
- Renamed `roslyn_ls` to `roslyn-ls`
|
- Renamed `roslyn_ls` to `roslyn-ls`
|
||||||
|
|
|
||||||
|
|
@ -373,5 +373,10 @@ in {
|
||||||
<https://strongly-typed-thoughts.net/blog/final-bye-github>
|
<https://strongly-typed-thoughts.net/blog/final-bye-github>
|
||||||
'')
|
'')
|
||||||
]
|
]
|
||||||
|
|
||||||
|
# 2026-05-16
|
||||||
|
[
|
||||||
|
(mkRenamedOptionModule ["vim" "languages" "typescript" "treesitter" "tsxPackage"] ["vim" "languages" "tsx" "treesitter" "package"])
|
||||||
|
]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,70 +7,72 @@ in {
|
||||||
./asm.nix
|
./asm.nix
|
||||||
./astro.nix
|
./astro.nix
|
||||||
./bash.nix
|
./bash.nix
|
||||||
./env.nix
|
|
||||||
./cue.nix
|
|
||||||
./dart.nix
|
|
||||||
./clang.nix
|
./clang.nix
|
||||||
./clojure.nix
|
./clojure.nix
|
||||||
./cmake.nix
|
./cmake.nix
|
||||||
|
./csharp.nix
|
||||||
./css.nix
|
./css.nix
|
||||||
./standard-ml.nix
|
./cue.nix
|
||||||
./scss.nix
|
./dart.nix
|
||||||
|
./docker.nix
|
||||||
./elixir.nix
|
./elixir.nix
|
||||||
./elm.nix
|
./elm.nix
|
||||||
|
./env.nix
|
||||||
./fish.nix
|
./fish.nix
|
||||||
|
./fluent.nix
|
||||||
./fsharp.nix
|
./fsharp.nix
|
||||||
|
./gettext.nix
|
||||||
./gleam.nix
|
./gleam.nix
|
||||||
./glsl.nix
|
./glsl.nix
|
||||||
./go.nix
|
./go.nix
|
||||||
|
./haskell.nix
|
||||||
./hcl.nix
|
./hcl.nix
|
||||||
./helm.nix
|
./helm.nix
|
||||||
./kotlin.nix
|
|
||||||
./html.nix
|
./html.nix
|
||||||
./tera.nix
|
|
||||||
./twig.nix
|
|
||||||
./liquid.nix
|
|
||||||
./haskell.nix
|
|
||||||
./java.nix
|
./java.nix
|
||||||
./jinja.nix
|
./jinja.nix
|
||||||
|
./jq.nix
|
||||||
./json.nix
|
./json.nix
|
||||||
|
./julia.nix
|
||||||
|
./just.nix
|
||||||
|
./kotlin.nix
|
||||||
|
./liquid.nix
|
||||||
./lua.nix
|
./lua.nix
|
||||||
|
./make.nix
|
||||||
./markdown.nix
|
./markdown.nix
|
||||||
./tex.nix
|
|
||||||
./nim.nix
|
./nim.nix
|
||||||
./vala.nix
|
|
||||||
./nix.nix
|
./nix.nix
|
||||||
|
./nu.nix
|
||||||
./ocaml.nix
|
./ocaml.nix
|
||||||
|
./odin.nix
|
||||||
|
./openscad.nix
|
||||||
./php.nix
|
./php.nix
|
||||||
./python.nix
|
./python.nix
|
||||||
./qml.nix
|
./qml.nix
|
||||||
./r.nix
|
./r.nix
|
||||||
|
./ruby.nix
|
||||||
./rust.nix
|
./rust.nix
|
||||||
./scala.nix
|
./scala.nix
|
||||||
|
./scss.nix
|
||||||
|
./scss.nix
|
||||||
./sql.nix
|
./sql.nix
|
||||||
|
./standard-ml.nix
|
||||||
./svelte.nix
|
./svelte.nix
|
||||||
./vhdl.nix
|
./tera.nix
|
||||||
./vue.nix
|
|
||||||
./terraform.nix
|
./terraform.nix
|
||||||
|
./tex.nix
|
||||||
./toml.nix
|
./toml.nix
|
||||||
|
./tsx.nix
|
||||||
|
./twig.nix
|
||||||
./typescript.nix
|
./typescript.nix
|
||||||
./typst.nix
|
./typst.nix
|
||||||
./zig.nix
|
./vala.nix
|
||||||
./csharp.nix
|
./vhdl.nix
|
||||||
./julia.nix
|
./vue.nix
|
||||||
./nu.nix
|
|
||||||
./odin.nix
|
|
||||||
./wgsl.nix
|
./wgsl.nix
|
||||||
./yaml.nix
|
|
||||||
./ruby.nix
|
|
||||||
./just.nix
|
|
||||||
./make.nix
|
|
||||||
./xml.nix
|
./xml.nix
|
||||||
./gettext.nix
|
./yaml.nix
|
||||||
./fluent.nix
|
./zig.nix
|
||||||
./openscad.nix
|
|
||||||
./jq.nix
|
|
||||||
./docker.nix
|
|
||||||
|
|
||||||
# This is now a hard deprecation.
|
# This is now a hard deprecation.
|
||||||
(mkRenamedOptionModule ["vim" "languages" "enableLSP"] ["vim" "lsp" "enable"])
|
(mkRenamedOptionModule ["vim" "languages" "enableLSP"] ["vim" "lsp" "enable"])
|
||||||
|
|
|
||||||
159
modules/plugins/languages/tsx.nix
Normal file
159
modules/plugins/languages/tsx.nix
Normal file
|
|
@ -0,0 +1,159 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}: let
|
||||||
|
inherit (lib.modules) mkIf mkMerge;
|
||||||
|
inherit (lib.options) mkEnableOption mkOption literalExpression;
|
||||||
|
inherit (lib.types) enum listOf;
|
||||||
|
inherit (lib.attrsets) attrNames genAttrs;
|
||||||
|
inherit (lib.meta) getExe;
|
||||||
|
inherit (lib.nvim.attrsets) mapListToAttrs;
|
||||||
|
inherit (lib.nvim.types) mkGrammarOption diagnostics;
|
||||||
|
|
||||||
|
cfg = config.vim.languages.tsx;
|
||||||
|
|
||||||
|
defaultServers = ["typescript-language-server"];
|
||||||
|
servers = ["typescript-language-server" "deno" "typescript-go" "emmet-ls"];
|
||||||
|
|
||||||
|
defaultFormat = ["prettier"];
|
||||||
|
formats = {
|
||||||
|
prettier = {
|
||||||
|
command = getExe pkgs.prettier;
|
||||||
|
};
|
||||||
|
|
||||||
|
prettierd = {
|
||||||
|
command = getExe pkgs.prettierd;
|
||||||
|
};
|
||||||
|
|
||||||
|
biome = {
|
||||||
|
command = getExe pkgs.biome;
|
||||||
|
};
|
||||||
|
|
||||||
|
biome-check = {
|
||||||
|
command = getExe pkgs.biome;
|
||||||
|
};
|
||||||
|
|
||||||
|
biome-organize-imports = {
|
||||||
|
command = getExe pkgs.biome;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
defaultDiagnosticsProvider = ["biomejs"];
|
||||||
|
diagnosticsProviders = {
|
||||||
|
biomejs = let
|
||||||
|
pkg = pkgs.biome;
|
||||||
|
in {
|
||||||
|
package = pkg;
|
||||||
|
config = {
|
||||||
|
cmd = getExe pkg;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
in {
|
||||||
|
options.vim.languages.tsx = {
|
||||||
|
enable = mkEnableOption "Typescript XML (TSX) language support";
|
||||||
|
|
||||||
|
treesitter = {
|
||||||
|
enable =
|
||||||
|
mkEnableOption "Typescript XML (TSX) treesitter"
|
||||||
|
// {
|
||||||
|
default = config.vim.languages.enableTreesitter;
|
||||||
|
defaultText = literalExpression "config.vim.languages.enableTreesitter";
|
||||||
|
};
|
||||||
|
package = mkGrammarOption pkgs "tsx";
|
||||||
|
};
|
||||||
|
|
||||||
|
lsp = {
|
||||||
|
enable =
|
||||||
|
mkEnableOption "Typescript XML (TSX) LSP support"
|
||||||
|
// {
|
||||||
|
default = config.vim.lsp.enable;
|
||||||
|
defaultText = literalExpression "config.vim.lsp.enable";
|
||||||
|
};
|
||||||
|
servers = mkOption {
|
||||||
|
type = listOf (enum servers);
|
||||||
|
default = defaultServers;
|
||||||
|
description = "Typescript XML (TSX) LSP server to use";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
format = {
|
||||||
|
enable =
|
||||||
|
mkEnableOption "Typescript XML (TSX) formatting"
|
||||||
|
// {
|
||||||
|
default = config.vim.languages.enableFormat;
|
||||||
|
defaultText = literalExpression "config.vim.languages.enableFormat";
|
||||||
|
};
|
||||||
|
|
||||||
|
type = mkOption {
|
||||||
|
description = "Typescript XML (TSX) formatter to use";
|
||||||
|
type = listOf (enum (attrNames formats));
|
||||||
|
default = defaultFormat;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
extraDiagnostics = {
|
||||||
|
enable = mkEnableOption "extra Typescript XML (TSX) diagnostics" // {default = config.vim.languages.enableExtraDiagnostics;};
|
||||||
|
|
||||||
|
types = diagnostics {
|
||||||
|
langDesc = "Typescript XML (TSX)";
|
||||||
|
inherit diagnosticsProviders;
|
||||||
|
inherit defaultDiagnosticsProvider;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable (mkMerge [
|
||||||
|
(mkIf cfg.treesitter.enable {
|
||||||
|
vim.treesitter = {
|
||||||
|
enable = true;
|
||||||
|
grammars = [cfg.treesitter.package];
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
(mkIf cfg.lsp.enable {
|
||||||
|
vim.lsp = {
|
||||||
|
presets = genAttrs cfg.lsp.servers (_: {enable = true;});
|
||||||
|
servers = genAttrs cfg.lsp.servers (_: {
|
||||||
|
filetypes = [
|
||||||
|
"typescriptreact"
|
||||||
|
"javascriptreact"
|
||||||
|
];
|
||||||
|
});
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
(mkIf cfg.format.enable {
|
||||||
|
vim.formatter.conform-nvim = {
|
||||||
|
enable = true;
|
||||||
|
setupOpts = {
|
||||||
|
formatters_by_ft = {
|
||||||
|
typescriptreact = cfg.format.type;
|
||||||
|
javascriptreact = cfg.format.type;
|
||||||
|
};
|
||||||
|
formatters =
|
||||||
|
mapListToAttrs (name: {
|
||||||
|
inherit name;
|
||||||
|
value = formats.${name};
|
||||||
|
})
|
||||||
|
cfg.format.type;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})
|
||||||
|
|
||||||
|
(mkIf cfg.extraDiagnostics.enable {
|
||||||
|
vim.diagnostics.nvim-lint = {
|
||||||
|
enable = true;
|
||||||
|
linters_by_ft = {
|
||||||
|
typescriptreact = cfg.extraDiagnostics.types;
|
||||||
|
javascriptreact = cfg.extraDiagnostics.types;
|
||||||
|
};
|
||||||
|
linters =
|
||||||
|
mkMerge (map (name: {${name} = diagnosticsProviders.${name}.config;})
|
||||||
|
cfg.extraDiagnostics.types);
|
||||||
|
};
|
||||||
|
})
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
@ -85,7 +85,6 @@ in {
|
||||||
defaultText = literalExpression "config.vim.languages.enableTreesitter";
|
defaultText = literalExpression "config.vim.languages.enableTreesitter";
|
||||||
};
|
};
|
||||||
tsPackage = mkGrammarOption pkgs "typescript";
|
tsPackage = mkGrammarOption pkgs "typescript";
|
||||||
tsxPackage = mkGrammarOption pkgs "tsx";
|
|
||||||
jsPackage = mkGrammarOption pkgs "javascript";
|
jsPackage = mkGrammarOption pkgs "javascript";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -162,7 +161,6 @@ in {
|
||||||
vim.treesitter.enable = true;
|
vim.treesitter.enable = true;
|
||||||
vim.treesitter.grammars = [
|
vim.treesitter.grammars = [
|
||||||
cfg.treesitter.tsPackage
|
cfg.treesitter.tsPackage
|
||||||
cfg.treesitter.tsxPackage
|
|
||||||
cfg.treesitter.jsPackage
|
cfg.treesitter.jsPackage
|
||||||
];
|
];
|
||||||
})
|
})
|
||||||
|
|
@ -173,11 +171,6 @@ in {
|
||||||
servers = genAttrs cfg.lsp.servers (_: {
|
servers = genAttrs cfg.lsp.servers (_: {
|
||||||
filetypes = [
|
filetypes = [
|
||||||
"typescript"
|
"typescript"
|
||||||
# TODO: move to a React module
|
|
||||||
"typescriptreact"
|
|
||||||
"typescript.tsx"
|
|
||||||
"javascriptreact"
|
|
||||||
"javascript.jsx"
|
|
||||||
# TODO: move to a JavaScript module
|
# TODO: move to a JavaScript module
|
||||||
"javascript"
|
"javascript"
|
||||||
];
|
];
|
||||||
|
|
@ -192,8 +185,6 @@ in {
|
||||||
formatters_by_ft = {
|
formatters_by_ft = {
|
||||||
typescript = cfg.format.type;
|
typescript = cfg.format.type;
|
||||||
javascript = cfg.format.type;
|
javascript = cfg.format.type;
|
||||||
# .tsx/.jsx files
|
|
||||||
typescriptreact = cfg.format.type;
|
|
||||||
};
|
};
|
||||||
formatters =
|
formatters =
|
||||||
mapListToAttrs (name: {
|
mapListToAttrs (name: {
|
||||||
|
|
@ -209,8 +200,6 @@ in {
|
||||||
vim.diagnostics.nvim-lint = {
|
vim.diagnostics.nvim-lint = {
|
||||||
enable = true;
|
enable = true;
|
||||||
linters_by_ft.typescript = cfg.extraDiagnostics.types;
|
linters_by_ft.typescript = cfg.extraDiagnostics.types;
|
||||||
linters_by_ft.typescriptreact = cfg.extraDiagnostics.types;
|
|
||||||
|
|
||||||
linters =
|
linters =
|
||||||
mkMerge (map (name: {${name} = diagnosticsProviders.${name}.config;})
|
mkMerge (map (name: {${name} = diagnosticsProviders.${name}.config;})
|
||||||
cfg.extraDiagnostics.types);
|
cfg.extraDiagnostics.types);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue