Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yaegassy/coc-astro
Astro extension for coc.nvim
https://github.com/yaegassy/coc-astro
astro coc coc-extensions coc-nvim neovim vim
Last synced: 15 days ago
JSON representation
Astro extension for coc.nvim
- Host: GitHub
- URL: https://github.com/yaegassy/coc-astro
- Owner: yaegassy
- License: mit
- Created: 2023-03-09T03:59:14.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-10-27T23:25:28.000Z (2 months ago)
- Last Synced: 2024-12-10T00:42:04.672Z (24 days ago)
- Topics: astro, coc, coc-extensions, coc-nvim, neovim, vim
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/@yaegassy/coc-astro
- Size: 461 KB
- Stars: 29
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# coc-astro
> fork from a [astro-vscode](https://github.com/withastro/language-tools/tree/main/packages/vscode)
Astro extension for [coc.nvim](https://github.com/neoclide/coc.nvim)
## Install
**CocInstall**:
```vim
:CocInstall @yaegassy/coc-astro
```> scoped packages
**e.g. vim-plug**:
```vim
Plug 'yaegassy/coc-astro', {'do': 'yarn install --frozen-lockfile'}
```## Note
### Filetype related
The "filetype" must be `astro` for this extension to work.
Install "astro" related plugin. (e.g. [vim-astro](https://github.com/wuelnerdotexe/vim-astro) or [nvim-treesitter](https://github.com/nvim-treesitter/nvim-treesitter)).
### How to set up TypeScript in your Astro project for coc.nvim
1. You need [coc-tsserver](https://github.com/neoclide/coc-tsserver). Please install it if you haven't already.
1. `coc-astro` has a setting to use `@astrojs/ts-plugin` in the extension as well as `astro-vscode`, so you can use typescript as it is.
## [RECOMMENDED] Additional installation of "watchman"
In the `@astrojs/language-server` used by `coc-astro`, it utilizes the `workspace/didChangeWatchedFiles` notification to watch files within the project.
In coc.nvim, it is recommended to install [watchman](https://facebook.github.io/watchman/) in order to utilize this feature.
- See:
If you have difficulty installing `watchman`, you can use `coc-astro` without `watchman`, but you may not be able to immediately use IntelliSense with the newly added files.
In this case, please execute the command to restart the language server.
- `:CocRestart`
## Dealing with text corruption when determining completion item
coc-astro provides a setting called `astro.disableResolveCompletionItem`. Set this setting to `true` in `coc-settings.json`. The default is `false`.
Please note that if this setting is set to `true`, feature such as "auto-import" upon completion item determination will not work.
**coc-settings.json**:
```json
{
"astro.disableResolveCompletionItem": true
}
```- Related issues in upstream
-## Configuration options
- `astro.enable`: Enable coc-astro extension, default: `true`
- `astro.disableResolveCompletionItem`: Disable `completionItem/resolve` feature, default: `false`
- `astro.useWorkspaceTsdk`: Use workspace (project) detected tsLibs in astro. if false, use coc-astro's built-in tsLibs, default: `false`
- `astro.language-server.ls-path`: Path to the language server executable. You won't need this in most cases, set this only when needing a specific version of the language server, default: `null`
- `astro.language-server.runtime`: Path to the node executable used to execute the language server. You won't need this in most cases, default: `null`
- `astro.trace.server`: Traces the communication between coc.nvim and the language server, valid option: `["off", "messages", "verbose"]`, default: `"off"`## Commands
- `astro.findFileReferences`: Astro: Find File References
- `astro.reloadProject`: Astro: Reload Project## Thanks
- [withastro/language-tools](https://github.com/withastro/language-tools)
## License
MIT
---
> This extension is built with [create-coc-extension](https://github.com/fannheyward/create-coc-extension)