From af735977fd6b31d994b6946c28c70235882564bb Mon Sep 17 00:00:00 2001
From: qvalentin <36446499+qvalentin@users.noreply.github.com>
Date: Sun, 27 Oct 2024 20:11:47 +0100
Subject: [PATCH] docs: add features overview and zed to README (#113)
* chore: add features to README
* chore: demos of features in readme
* docs: cleanup
* docs: add zed extension
* docs: add demo to heading
---
README.md | 77 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 77 insertions(+)
diff --git a/README.md b/README.md
index 19be4f3..7807b66 100644
--- a/README.md
+++ b/README.md
@@ -39,7 +39,9 @@ Helm-ls is a [helm](https://github.com/helm/helm) language server protocol [LSP]
- [nvim-lspconfig setup](#nvim-lspconfig-setup)
- [coc.nvim setup](#cocnvim-setup)
- [VSCode](#vscode)
+ - [Zed](#zed)
- [Emacs eglot setup](#emacs-eglot-setup)
+- [Features and Demos](#features-and-demos)
- [Contributing](#contributing)
- [License](#license)
@@ -270,6 +272,10 @@ Save the configuration file and then either restart Neovim or type `:CocRestart`
Check out the [helm-ls-vscode extension](https://github.com/qvalentin/helm-ls-vscode) for more details.
+### Zed
+
+Setup filetypes as described in the [Zed Docs](https://zed.dev/docs/languages/helm) and install the [helm.zed extension](https://github.com/cabrinha/helm.zed).
+
### Emacs eglot setup
Integrating helm-ls with [eglot](https://github.com/joaotavora/eglot) for emacs consists of two steps: wiring up Helm template files into a specific major mode and then associating that major mode with `helm_ls` via the `eglot-server-programs` variable.
@@ -304,6 +310,77 @@ Alternatively, you can include a comment such as the following at the top of Hel
# -*- mode: helm -*-
+## Features and Demos
+
+
+
+ Hover
+
+
+
+
+| Language Construct | Example Effect |
+| ------------------ | ---------------------------------------------------------------------------------- |
+| Values | `.Values.replicaCount` shows the value of `replicaCount` in the values.yaml files. |
+| Built-In-Objects | `.Chart.Name` shows the name of the Chart. |
+| Includes | `include "example.labels"` shows the defintion of the template. |
+| Functions | `add` shows the docs of the add function. |
+| Yaml in Templates | `Kind` shows the docs from the yaml-schema (via yaml-language-server). |
+
+
+
+
+
+ Autocomplete
+
+
+
+
+| Language Construct | Effect |
+| ------------------ | -------------------------------------------------------------------- |
+| Values | Values from `values*.yaml` files (including child/parent Charts). |
+| Built-In-Objects | Values from `Chart`, `Release`, `Files`, `Capabilities`, `Template`. |
+| Includes | Available includes (including child/parent Charts). |
+| Functions | Functions from gotemplate and helm. |
+| Yaml in Templates | Values from the yaml-schema (via yaml-language-server). |
+
+
+
+
+
+ Go-To-Definition/References
+
+
+
+
+| Language Construct | Effect |
+| ------------------ | ----------------------------------------------------------------------------------- |
+| Values | Go to `values*.yaml` files for template references (including child/parent Charts). |
+| Built-In-Objects | Go to `Chart.yaml` for `Chart.*`. |
+| Includes | Go to defintion/references of template (including child/parent Charts). |
+
+
+
+
+
+ Symbol
+
+
+Can show a breadcrumb of the yaml path of the current position (via yaml-language-server).
+![Demo for Symbol](https://github.com/user-attachments/assets/0b8a9fc4-4625-4641-a296-8aedb48496e9)
+
+
+
+
+
+ Linting
+
+
+Diagnostics from both helm lint and yaml-language-server.
+![Demo of Linting](https://github.com/user-attachments/assets/58e90dd4-2fe5-40f5-a9a7-adec6c890a0c)
+
+
+
## Contributing
Thank you for considering contributing to Helm-ls project!