2018-09-07 20:40:51 +08:00
# coc-tsserver
2020-08-08 10:03:33 +08:00
Tsserver language server extension for
[coc.nvim ](https://github.com/neoclide/coc.nvim ).
2018-09-07 20:40:51 +08:00
2020-06-29 11:37:20 +08:00
Tsserver is part of [TypeScript ](https://github.com/microsoft/TypeScript ) which
provide rich features for javascript and typescript.
2020-08-08 10:03:33 +08:00
This extension is a fork of `typescript-language-features` extension which is
bundled with VSCode.
2018-09-07 20:40:51 +08:00
2019-06-11 16:23:34 +12:00
**Note:** for React to work as expected, you need your JSX filetype to be
2020-08-08 10:03:33 +08:00
`javascript.jsx` or `javascriptreact` and your TSX filetype to be
`typescript.jsx` or `typescript.tsx` or `typescriptreact` . In coc.nvim, these
filetypes are mapped to `javascriptreact` and `typescriptreact` because that's
2020-09-10 21:10:52 +08:00
what tsserver uses. For filetype like `typescript.javascript` , you need
configure `g:coc_filetype_map` variable in vimrc.
2019-03-27 19:02:33 +08:00
2020-08-08 10:03:33 +08:00
**Note** for javascript project, configure
[jsconfig.json ](https://code.visualstudio.com/docs/languages/jsconfig ) to make
tsserver understand your code.
2020-05-22 14:07:39 +08:00
2020-11-02 18:18:39 +08:00
**Note:** for rename import on file rename, you have to install
[watchman ](https://facebook.github.io/watchman/ ) in your \$PATH.
**Note:** for [nvm ](https://github.com/creationix/nvm ) users, you need configure
`tsserver.npm` to your global npm path or configure
`"tsserver.disableAutomaticTypeAcquisition": false` to disable automatic typings
installation.
**Note:** tsserver could be quite slow to initialize on big project, exclude
2021-12-21 06:57:51 +01:00
unnecessary files in your jsconfig.json/tsconfig.json.
2020-11-02 18:18:39 +08:00
2021-01-19 08:16:58 +02:00
**Note:** if you're using WSL, copy you project files from mounted dirs to linux home otherwise tsserver will not work properly.
2020-12-09 15:41:00 +08:00
## Supporting
If you like my extension, consider supporting me on Patreon or PayPal:
< a href = "https://www.patreon.com/chemzqm" > < img src = "https://c5.patreon.com/external/logo/become_a_patron_button.png" alt = "Patreon donate button" / > < / a >
< a href = "https://www.paypal.com/paypalme/chezqm" > < img src = "https://werwolv.net/assets/paypal_banner.png" alt = "PayPal donate button" / > < / a >
2018-09-07 20:40:51 +08:00
## Install
In your vim/neovim, run command:
2020-08-08 10:03:33 +08:00
`:CocInstall coc-tsserver`
2018-09-07 20:40:51 +08:00
2020-06-29 11:37:20 +08:00
For yarn2 ( >= v2.0.0-rc.36) user want to use local typescript module:
2020-04-17 12:19:17 +08:00
2021-12-21 13:52:08 +08:00
- Run command `yarn dlx @yarnpkg/sdks vim` , which will generate
2020-08-08 10:03:33 +08:00
`.vim/coc-settings.json` , with content:
2020-04-17 12:19:17 +08:00
2021-02-09 19:54:01 +09:00
```json
2020-10-27 16:24:53 +08:00
{
"eslint.packageManager": "yarn",
2021-12-21 13:52:08 +08:00
"eslint.nodePath": ".yarn/sdks",
"workspace.workspaceFolderCheckCwd": false,
"tsserver.tsdk": ".yarn/sdks/typescript/lib"
2021-02-09 19:54:01 +09:00
}
```
2020-04-17 12:19:17 +08:00
2018-09-07 20:40:51 +08:00
## Features
2019-04-19 21:52:07 +02:00
Almost the same as VSCode.
2018-09-07 20:40:51 +08:00
2019-04-19 21:52:07 +02:00
- Supports javascript & typescript and jsx/tsx.
- Installs typings automatically.
2018-10-21 13:21:25 +08:00
- Commands to work with tsserver, including:
- `tsserver.reloadProjects`
- `tsserver.openTsServerLog`
- `tsserver.goToProjectConfig`
- `tsserver.restart`
- `tsserver.organizeImports`
- `tsserver.watchBuild`
2021-06-04 18:54:48 +08:00
- `tsserver.findAllFileReferences`
2018-10-21 13:21:25 +08:00
- Code completion support.
2021-04-07 12:28:07 +02:00
- Go to definition (more info in [microsoft/TypeScript#37777 ](https://github.com/microsoft/TypeScript/issues/37777 ))
2018-10-21 13:21:25 +08:00
- Code validation.
- Document highlight.
- Document symbols of current buffer.
- Folding and folding range of current buffer.
- Format current buffer, range format and format on type.
- Hover for documentation.
- Implementations codeLens and references codeLens.
- Organize imports command.
- Quickfix using code actions.
- Code refactor using code actions.
- Find references.
- Signature help.
2022-01-20 04:08:19 +08:00
- Call hierarchy.
- Selection range.
2022-01-19 23:22:30 +08:00
- Semantic tokens.
2018-10-21 13:21:25 +08:00
- Rename symbols support.
2022-01-19 23:22:30 +08:00
- Automatic tag closing.
2020-08-08 10:03:33 +08:00
- Rename imports on file rename, require
[watchman ](https://facebook.github.io/watchman/ ) installed in your \$PATH.
2018-10-21 13:21:25 +08:00
- Search for workspace symbols.
2021-12-24 18:39:29 +08:00
- Inlay hints support using virtual text feature of neovim, which requires:
- TypeScript >= 4.4.0
- Neovim >= 0.4.0
- Enabled by options starts with `typescript.inlayHints` or
`javascript.inlayHints` .
2018-09-07 20:40:51 +08:00
2020-08-08 10:03:33 +08:00
Tsserver module first resolved from your local workspace. If it's not found, use
tsserver from `tsserver.tsdk` configuration or use bundled tsserver with this
extension.
2018-10-14 10:06:11 +08:00
2018-09-07 20:40:51 +08:00
## Configuration options
2020-08-08 10:03:33 +08:00
Checkout [using the configuration
file](https://github.com/neoclide/coc.nvim/wiki/Using-the-configuration-file)
for guide of coc.nvim's configuration.
2019-11-23 18:40:48 +08:00
2019-04-19 19:07:15 +08:00
- `tsserver.enable` :Enable tsserver extension, default: `true`
- `tsserver.locale` :Locale of tsserver, default: `""`
2022-02-16 18:48:32 +08:00
- `tsserver.ignoreLocalTsserver` :Always use tsserver module from tsserver.tsdk
or coc-tsserver extension.
2019-04-19 19:07:15 +08:00
- `tsserver.typingsCacheLocation` :Folder path for cache typings, default: `""`
2020-08-08 10:03:33 +08:00
- `tsserver.formatOnType` :Run format on type special characters., default:
`true`
2019-04-19 19:07:15 +08:00
- `tsserver.enableJavascript` :Use tsserver for javascript files, default: `true`
2020-08-08 10:03:33 +08:00
- `tsserver.maxTsServerMemory` :Set the maximum amount of memory to allocate to
the TypeScript server process
2019-04-19 19:07:15 +08:00
- `tsserver.tsdk` :Directory contains tsserver.js,, default: `""`
- `tsserver.npm` :Executable path of npm for download typings, default: `""`
- `tsserver.log` :Log level of tsserver, default: `"off"`
- `tsserver.trace.server` :Trace level of tsserver, default: `"off"`
2020-07-13 19:56:13 +08:00
- `tsserver.pluginPaths` :Folders contains tsserver plugins, default: `[]`
2020-08-08 10:03:33 +08:00
- `tsserver.watchOptions` :Configure which watching strategies should be used to
keep track of files and directories. Requires using TypeScript 3.8+ in the
2021-12-21 06:57:51 +01:00
workspace, default: `undefined`
2019-04-19 19:07:15 +08:00
- `tsserver.reportStyleChecksAsWarnings` default: `true`
2020-08-08 10:03:33 +08:00
- `tsserver.implicitProjectConfig.checkJs` :Enable checkJs for implicit project,
default: `false`
- `tsserver.implicitProjectConfig.experimentalDecorators` :Enable
experimentalDecorators for implicit project, default: `false`
- `tsserver.disableAutomaticTypeAcquisition` :Disable download of typings,
2021-12-21 06:57:51 +01:00
default: `false`
- `tsserver.useBatchedBufferSync` : use batched buffer synchronize support, default: `true`
2021-12-21 18:04:20 +08:00
- `tsserver.enableTracing` : Enables tracing TS server performance to a
directory. These trace files can be used to diagnose TS Server performance
issues. The log may contain file paths, source code, and other potentially
sensitive information from your project, default: `false`
2021-12-22 01:17:42 +08:00
- `typescript.check.npmIsInstalled` : Check if npm is installed for [Automatic
Type
Acquisition](https://code.visualstudio.com/docs/nodejs/working-with-javascript#_typings -and-automatic-type-acquisition).
2020-08-08 10:03:33 +08:00
- `typescript.updateImportsOnFileMove.enable` :Enable update imports on file
move., default: `true`
- `typescript.implementationsCodeLens.enable` :Enable codeLens for
implementations, default: `true`
- `typescript.referencesCodeLens.enable` :Enable codeLens for references,
default: `true`
2022-01-13 00:29:12 +08:00
- `typescript.referencesCodeLens.showOnAllFunctions` : Enable/disable references CodeLens on all functions in typescript files. Default: `false`
2022-01-27 14:59:53 -07:00
- `typescript.preferences.importModuleSpecifier` default: `"shortest"`
2020-12-13 14:33:55 +09:00
- `typescript.preferences.importModuleSpecifierEnding` default: `"auto"`
2019-04-19 19:07:15 +08:00
- `typescript.preferences.quoteStyle` default: `"single"`
2021-12-21 17:38:28 +08:00
- `typescript.preferences.includePackageJsonAutoImports` : Enable/disable
searching `package.json` dependencies for available auto imports, default:
`"auto"`
2020-08-08 10:03:33 +08:00
- `typescript.suggestionActions.enabled` :Enable/disable suggestion diagnostics
for TypeScript files in the editor. Requires using TypeScript 2.8 or newer in
the workspace., default: `true`
- `typescript.validate.enable` :Enable/disable TypeScript validation., default:
`true`
2019-06-27 10:43:32 +08:00
- `typescript.showUnused` : show unused variable hint, default: `true` .
2022-01-20 04:04:13 +08:00
- `typescript.autoClosingTags` : Enable/disable autoClosing of JSX tags, default: `true`
2019-04-19 19:07:15 +08:00
- `typescript.suggest.enabled` default: `true`
2020-08-08 10:03:33 +08:00
- `typescript.suggest.paths` :Enable/disable suggest paths in import statement
and require calls, default: `true`
2021-12-21 06:57:51 +01:00
- `typescript.suggest.autoImports` :Enable/disable auto import suggests,
2020-08-08 10:03:33 +08:00
default: `true`
- `typescript.suggest.completeFunctionCalls` :Enable snippet for method
suggestion, default: `true`
2021-05-28 18:45:47 +08:00
- `typescript.suggest.includeCompletionsForImportStatements` : Enable/disable
auto-import-style completions on partially-typed import statements. Requires using
TypeScript 4.3+ in the workspace, default: `true`
- `typescript.suggest.includeCompletionsWithSnippetText` : Enable snippet completions
from TS Server. Requires using TypeScript 4.3+ in the workspace, default: `true`
2021-12-21 17:00:49 +08:00
- `typescript.suggest.classMemberSnippets.enabled` : Enable/disable
2021-12-21 13:54:47 +08:00
snippet completions for class members. Requires using TypeScript 4.5+ in the
workspace, default: `true`
2021-12-21 17:22:46 +08:00
- `typescript.suggest.jsdoc.generateReturns` : Enable/disable generating
`@return` annotations for JSDoc templates. Requires using TypeScript 4.2+ in
the workspace. default: `true`
2022-01-19 23:22:30 +08:00
- `typescript.suggest.includeAutomaticOptionalChainCompletions` : default: `true`
2019-11-23 17:12:58 +08:00
- `typescript.format.enabled` :Enable/disable format of typescript files.
2019-04-19 19:07:15 +08:00
- `typescript.format.insertSpaceAfterCommaDelimiter` default: `true`
- `typescript.format.insertSpaceAfterConstructor` default: `false`
- `typescript.format.insertSpaceAfterSemicolonInForStatements` default: `true`
- `typescript.format.insertSpaceBeforeAndAfterBinaryOperators` default: `true`
2020-08-08 10:03:33 +08:00
- `typescript.format.insertSpaceAfterKeywordsInControlFlowStatements` default:
`true`
- `typescript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions`
default: `true`
2019-04-19 19:07:15 +08:00
- `typescript.format.insertSpaceBeforeFunctionParenthesis` default: `false`
2020-08-08 10:03:33 +08:00
- `typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets`
default: `false`
2020-12-10 16:55:04 +08:00
- `typescript.format.insertSpaceAfterOpeningAndBeforeClosingEmptyBraces`
default: `false`
2020-08-08 10:03:33 +08:00
- `typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces`
default: `false`
- `typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis`
default: `false`
- `typescript.format.insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces`
default: `false`
- `typescript.format.insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces`
default: `false`
2019-04-19 19:07:15 +08:00
- `typescript.format.insertSpaceAfterTypeAssertion` default: `false`
- `typescript.format.placeOpenBraceOnNewLineForFunctions` default: `false`
- `typescript.format.placeOpenBraceOnNewLineForControlBlocks` default: `false`
2021-12-24 18:39:29 +08:00
- `typescript.inlayHints` : inlayHints related options.
2021-12-21 06:57:51 +01:00
- `javascript.format.enabled` : Enable/disable format for javascript files, default: `true`
- `javascript.showUnused` : show unused variable hint, default: `true`
2022-01-20 04:04:13 +08:00
- `javascript.autoClosingTags` : Enable/disable autoClosing of JSX tags, default: `true`
2019-04-19 19:07:15 +08:00
- `javascript.updateImportsOnFileMove.enable` default: `true`
- `javascript.implementationsCodeLens.enable` default: `true`
- `javascript.referencesCodeLens.enable` default: `true`
2022-01-13 00:29:12 +08:00
- `javascript.referencesCodeLens.showOnAllFunctions` : Enable/disable references CodeLens on all functions in JavaScript files default: `false`
2022-01-27 14:59:53 -07:00
- `javascript.preferences.importModuleSpecifier` default: `"shortest"`
2020-12-13 14:33:55 +09:00
- `javascript.preferences.importModuleSpecifierEnding` default: `"auto"`
2019-04-19 19:07:15 +08:00
- `javascript.preferences.quoteStyle` default: `"single"`
2020-08-08 10:03:33 +08:00
- `javascript.validate.enable` : Enable/disable JavaScript validation., default:
`true`
- `javascript.suggestionActions.enabled` : Enable/disable suggestion diagnostics
for JavaScript files in the editor. Requires using TypeScript 2.8 or newer in
the workspace., default: `true`
2019-11-23 17:12:58 +08:00
- `javascript.suggest.names` : default `true`
- `javascript.suggest.enabled` : default `true`
2020-08-08 10:03:33 +08:00
- `javascript.suggest.paths` : Enable/disable suggest paths in import statement
and require calls, default: `true`
- `javascript.suggest.autoImports` : Enable/disable auto import suggests.,
default: `true`
- `javascript.suggest.completeFunctionCalls` :Enable snippet for method
suggestion, default: `true`
2021-05-28 18:45:47 +08:00
- `javascript.suggest.includeCompletionsForImportStatements` : Enable/disable
auto-import-style completions on partially-typed import statements. Requires
using TypeScript 4.3+ in the workspace, default: `true`
2021-12-21 17:22:46 +08:00
- `javascript.suggest.jsdoc.generateReturns` : Enable/disable generating
`@return` annotations for JSDoc templates. Requires using TypeScript 4.2+ in
the workspace. default: `true`
2021-12-21 17:00:49 +08:00
- `javascript.suggest.classMemberSnippets.enabled` : Enable/disable
snippet completions for class members. Requires using TypeScript 4.5+ in the
workspace, default: `true`
2022-01-19 23:22:30 +08:00
- `javascript.suggest.includeAutomaticOptionalChainCompletions` : default: `true`
2019-04-19 19:07:15 +08:00
- `javascript.format.insertSpaceAfterCommaDelimiter` default: `true`
- `javascript.format.insertSpaceAfterConstructor` default: `false`
- `javascript.format.insertSpaceAfterSemicolonInForStatements` default: `true`
- `javascript.format.insertSpaceBeforeAndAfterBinaryOperators` default: `true`
2020-08-08 10:03:33 +08:00
- `javascript.format.insertSpaceAfterKeywordsInControlFlowStatements` default:
`true`
- `javascript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions`
default: `true`
2019-04-19 19:07:15 +08:00
- `javascript.format.insertSpaceBeforeFunctionParenthesis` default: `false`
2020-08-08 10:03:33 +08:00
- `javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets`
default: `false`
2020-12-10 16:55:04 +08:00
- `javascript.format.insertSpaceAfterOpeningAndBeforeClosingEmptyBraces`
default: `false`
2020-08-08 10:03:33 +08:00
- `javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces`
default: `false`
- `javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis`
default: `false`
- `javascript.format.insertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces`
default: `false`
- `javascript.format.insertSpaceAfterOpeningAndBeforeClosingJsxExpressionBraces`
default: `false`
2019-04-19 19:07:15 +08:00
- `javascript.format.insertSpaceAfterTypeAssertion` default: `false`
- `javascript.format.placeOpenBraceOnNewLineForFunctions` default: `false`
- `javascript.format.placeOpenBraceOnNewLineForControlBlocks` default: `false`
2021-12-24 18:39:29 +08:00
- `javascript.inlayHints` : inlayHints related options.
2019-04-19 19:07:15 +08:00
2022-01-19 23:22:30 +08:00
Configurations are the same as with VSCode. Install
[coc-json ](https://github.com/neoclide/coc-json ) and try completion with
`tsserver` , `typescript` or `javascript` in your
`coc-settings.json` .
2018-09-07 20:40:51 +08:00
2019-03-30 20:27:10 +08:00
## Related extensions
2020-02-07 01:23:48 -05:00
- [coc-eslint ](https://github.com/neoclide/coc-eslint ): enable [eslint ](https://github.com/eslint/eslint ) plugin for tsserver to lint TypeScript and JavaScript files.
2020-07-22 16:46:17 +08:00
- [coc-tslint-plugin ](https://github.com/neoclide/coc-tslint-plugin ): enable [tslint ](https://github.com/palantir/tslint ) plugin for tsserver ([deprecated ](https://github.com/palantir/tslint/issues/4534 )).
2020-07-22 15:49:18 +08:00
- [coc-styled-components ](https://github.com/fannheyward/coc-styled-components/ ): Styled component for coc.nvim as a tsserver plugin.
2020-07-22 16:46:17 +08:00
- [coc-react-refactor ](https://github.com/fannheyward/coc-react-refactor ): React refactor extension for coc.nvim, forked from vscode-react-refactor.
2019-03-30 20:27:10 +08:00
- [coc-vetur ](https://github.com/neoclide/coc-vetur ): [vue ](https://github.com/vuejs/vue ) extension.
- [coc-angular ](https://github.com/iamcco/coc-angular ): [angular ](https://github.com/angular/angular ) extension.
2019-11-20 03:31:38 +01:00
## Troubleshooting
2018-10-21 13:21:25 +08:00
- Add `"tsserver.log": "verbose"` to your `coc-settings.json` (opened by command
`:CocConfig` )
2018-11-18 22:40:30 +08:00
- To trace LSP communication, add `"tsserver.trace.server": "verbose"` to your
`coc-settings.json`
- Restart coc server by command `:CocRestart`
- Make the issue happen.
- Open tsserver log file by command `CocCommand tsserver.openTsServerLog`
- Open tsserver output channel by command `CocCommand workspace.showOutput tsserver`
2018-10-21 13:21:25 +08:00
2020-08-08 10:03:33 +08:00
If you find any issues, please [create an
issue](https://github.com/neoclide/coc-tsserver/issues/new).
2019-04-19 21:52:07 +02:00
2018-09-07 20:40:51 +08:00
## License
MIT