LSP-typescript
TypeScript, JavaScript support for Sublime LSP plugin
Details
Installs
- Total 38K
- Win 13K
- Mac 14K
- Linux 11K
Jan 21 | Jan 20 | Jan 19 | Jan 18 | Jan 17 | Jan 16 | Jan 15 | Jan 14 | Jan 13 | Jan 12 | Jan 11 | Jan 10 | Jan 9 | Jan 8 | Jan 7 | Jan 6 | Jan 5 | Jan 4 | Jan 3 | Jan 2 | Jan 1 | Dec 31 | Dec 30 | Dec 29 | Dec 28 | Dec 27 | Dec 26 | Dec 25 | Dec 24 | Dec 23 | Dec 22 | Dec 21 | Dec 20 | Dec 19 | Dec 18 | Dec 17 | Dec 16 | Dec 15 | Dec 14 | Dec 13 | Dec 12 | Dec 11 | Dec 10 | Dec 9 | Dec 8 | Dec 7 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 11 | 13 | 10 | 6 | 14 | 12 | 5 | 5 | 8 | 5 | 11 | 10 | 6 | 12 | 8 | 6 | 11 | 5 | 11 | 4 | 6 | 17 | 5 | 6 | 8 | 16 | 8 | 9 | 8 | 12 | 11 | 13 | 17 | 10 | 13 | 6 | 6 | 7 | 9 | 14 | 12 | 13 | 9 | 8 | 10 |
Mac | 0 | 10 | 6 | 5 | 10 | 11 | 11 | 17 | 12 | 3 | 8 | 4 | 8 | 12 | 8 | 4 | 5 | 3 | 11 | 7 | 5 | 6 | 3 | 4 | 7 | 9 | 12 | 8 | 9 | 3 | 7 | 9 | 11 | 20 | 10 | 6 | 8 | 4 | 6 | 9 | 11 | 7 | 8 | 10 | 3 | 5 |
Linux | 1 | 7 | 7 | 29 | 32 | 13 | 20 | 9 | 13 | 5 | 6 | 8 | 7 | 4 | 10 | 10 | 6 | 8 | 9 | 9 | 6 | 7 | 9 | 12 | 11 | 6 | 7 | 6 | 2 | 7 | 2 | 4 | 13 | 5 | 8 | 9 | 11 | 4 | 6 | 7 | 5 | 9 | 8 | 3 | 8 | 8 |
Readme
- Source
- raw.githubusercontent.com
LSP-typescript
TypeScript and JavaScript support for Sublime's LSP plugin provided through TypeScript Language Server.
Installation
- Install
LSP
andLSP-typescript
from Package Control. - For ST4: The TypeScript and React (TSX) syntaxes are built-in so no need to install anything else.
- For ST3: If you are working with TypeScript install TypeScript Syntax. If you are working with React install JSCustom.
- Restart Sublime.
Configuration
Open the configuration file using the Command Palette Preferences: LSP-typescript Settings
command or open it from the Sublime menu.
Organize Imports command
To sort or remove unused imports you can trigger the LSP-typescript: Organize Imports
command from the Command Palette or create a key binding. For example:
{ "keys": ["ctrl+k"], "command": "lsp_execute",
"args": {
"session_name": "LSP-typescript",
"command_name": "_typescript.organizeImports",
"command_args": ["${file}"]
}
},
Code Actions on Save
The server supports the following code actions that can be specified in the global lsp_code_actions_on_save
setting and run on saving files:
source.addMissingImports.ts
- adds imports for used but not imported symbolssource.fixAll.ts
- despite the name, fixes a couple of specific issues: unreachable code, await in non-async functions, incorrectly implemented interfacesource.organizeImports.ts
- organizes and removes unused importssource.removeUnused.ts
- removes declared but unused variablessource.removeUnusedImports.ts
- removes unused importssource.sortImports.ts
- sorts imports
Goto Source Definition command
TypeScript 4.7+ supports Go To Source Definition. It’s similar to Go To Definition, but it never returns results inside declaration files. Instead, it tries to find corresponding implementation files (like .js or .ts files), and find definitions there — even if those files are normally shadowed by .d.ts files.
This comes in handy most often when you need to peek at the implementation of a function you're importing from a library instead of its type declaration in a .d.ts file.
Run LSP-typescript: Goto Source Definition
from the Command Palette to invoke this functionality or bind lsp_typescript_goto_source_definition
to a custom key binding.
Inlay hints
Inlay hints are short textual annotations that show parameter names, type hints.
To enable inlay hints:
- Open the command palette and select
Preferences: LSP Settings
, then enableshow_inlay_hints
:
{
"show_inlay_hints": true
}
- Modify the following settings through
Preferences: LSP-typescript Settings
:
{
"settings": {
// Javascript inlay hints options.
"javascript.inlayHints.includeInlayEnumMemberValueHints": false,
"javascript.inlayHints.includeInlayFunctionLikeReturnTypeHints": false,
"javascript.inlayHints.includeInlayFunctionParameterTypeHints": false,
"javascript.inlayHints.includeInlayParameterNameHints": "none",
"javascript.inlayHints.includeInlayParameterNameHintsWhenArgumentMatchesName": false,
"javascript.inlayHints.includeInlayPropertyDeclarationTypeHints": false,
"javascript.inlayHints.includeInlayVariableTypeHints": false,
// Typescript inlay hints options.
"typescript.inlayHints.includeInlayEnumMemberValueHints": false,
"typescript.inlayHints.includeInlayFunctionLikeReturnTypeHints": false,
"typescript.inlayHints.includeInlayFunctionParameterTypeHints": false,
"typescript.inlayHints.includeInlayParameterNameHints": "none",
"typescript.inlayHints.includeInlayParameterNameHintsWhenArgumentMatchesName": false,
"typescript.inlayHints.includeInlayPropertyDeclarationTypeHints": false,
"typescript.inlayHints.includeInlayVariableTypeHints": false,
}
}
Note: Inlay hints require TypeScript 4.4+.
Usage in projects that also use Flow
TypeScript can check vanilla JavaScript, but may break on JavaScript with Flow types in it. To keep LSP-typescript enabled for TS and vanilla JS, while ignoring Flow-typed files, you must install JSCustom and configure it like so:
{
"configurations": {
"Flow": {
"scope": "source.js.flow",
"flow_types": true,
"jsx": true
}
}
}
Also install ApplySyntax and configure it like so:
{
"syntaxes": [
{
"syntax": "User/JS Custom/Syntaxes/Flow",
"match": "all",
"rules": [
{ "file_path": ".*\\.jsx?$" },
{ "first_line": "^/[/\\*] *@flow" }
]
}
]
}
And then configure LSP-typescript like so:
{
"selector": "source.js - source.js.flow, source.jsx, source.ts, source.tsx"
}
This works only on Sublime Text 4, and your project must have a // @flow
or /* @flow */
in each Flow-typed file. For more information, see this issue.