docs/src/languages/elixir.md
Elixir support is available through the Elixir extension.
The Elixir extension offers language server support for expert, elixir-ls, next-ls, and lexical.
elixir-ls is enabled by default.
Configure language servers in Settings ({#kb zed::OpenSettings}) under Languages > Elixir, or add to your settings file:
"languages": {
"Elixir": {
"language_servers": ["expert", "!elixir-ls", "!next-ls", "!lexical", "..."]
},
"HEEX": {
"language_servers": ["expert", "!elixir-ls", "!next-ls", "!lexical", "..."]
}
}
Configure language servers in Settings ({#kb zed::OpenSettings}) under Languages > Elixir, or add to your settings file:
"languages": {
"Elixir": {
"language_servers": ["next-ls", "!expert", "!elixir-ls", "!lexical", "..."]
},
"HEEX": {
"language_servers": ["next-ls", "!expert", "!elixir-ls", "!lexical", "..."]
}
}
Configure language servers in Settings ({#kb zed::OpenSettings}) under Languages > Elixir, or add to your settings file:
"languages": {
"Elixir": {
"language_servers": ["lexical", "!expert", "!elixir-ls", "!next-ls", "..."]
},
"HEEX": {
"language_servers": ["lexical", "!expert", "!elixir-ls", "!next-ls", "..."]
}
}
elixir-lselixir:brew install elixir
elixir-ls:brew install elixir-ls
If
elixir-lsis not running in an elixir project, check the error log via the command palette actionzed: open log. If you find an error message mentioning:invalid LSP message header "Shall I install Hex? (if running non-interactively, use \"mix local.hex --force\") [Yn], you might need to installHex. You runelixir-lsfrom the command line and accept the prompt to installHex.
If you prefer to format your code with Mix, configure it as an external formatter. Formatting will occur on file save.
Configure formatting in Settings ({#kb zed::OpenSettings}) under Languages > Elixir, or add to your settings file:
{
"languages": {
"Elixir": {
"format_on_save": "on",
"formatter": {
"external": {
"command": "mix",
"arguments": ["format", "--stdin-filename", "{buffer_path}", "-"]
}
}
}
}
}
You can pass additional elixir-ls workspace configuration options via lsp settings in your settings file (how to edit).
The following example disables dialyzer:
"lsp": {
"elixir-ls": {
"settings": {
"dialyzerEnabled": false
}
}
}
See ElixirLS configuration settings for more options.
Zed also supports HEEx templates. HEEx is a mix of EEx (Embedded Elixir) and HTML, and is used in Phoenix LiveView applications.
To get all features (autocomplete, linting, and hover docs) from the Tailwind CSS language server in HEEx files, add the following to your settings file (how to edit):
{
"lsp": {
"tailwindcss-language-server": {
"settings": {
"includeLanguages": {
"phoenix-heex": "html"
},
"experimental": {
"classRegex": ["class=\"([^\"]*)\"", "class='([^']*)'"]
}
}
}
}
}
With these settings, you will get completions for Tailwind CSS classes in HEEx template files. Examples:
<%!-- Standard class attribute --%>
<div class="flex items-center <completion here>">
<p class="text-lg font-bold <completion here>">Hello World</p>
</div>
<%!-- With Elixir expression --%>
<div class={"flex #{@custom_class} <completion here>"}>
Content
</div>
<%!-- With Phoenix function --%>
<div class={class_list(["flex", "items-center", "<completion here>"])}>
Content
</div>