#+TITLE: TypeScript layer [[file:img/TypeScript.png]] * Table of Contents :TOC_4_gh:noexport: - [[#description][Description]] - [[#install][Install]] - [[#pre-requisites][Pre-requisites]] - [[#layer][Layer]] - [[#notes][Notes]] - [[#configuration][Configuration]] - [[#key-bindings][Key bindings]] - [[#typescript-major-mode][Typescript Major Mode]] - [[#reference-major-mode][Reference Major Mode]] * Description This layer adds support for TypeScript and TSX editing. This layer provides: - Eldoc-mode - Documentation at point - Auto complete - Flycheck with linter - Jump to definition, Jump to type definition - Find occurrences (Imenu-mode) - Rename symbol - tsx mode - formatting - TypeScript playground integration * Install ** Pre-requisites You will need =node.js v0.12.0= or greater If you want linting run: =npm install -g typescript= =npm install -g tslint= If you want to use typescript-formatter for formatting run: =npm install -g typescript-formatter= For best results, make sure that the =auto-completion= (company) and =html= layers are enabled. ** Layer To use this configuration layer, add it to your =~/.spacemacs=. You will need to add =typescript= to the existing =dotspacemacs-configuration-layers= list in this file. #+BEGIN_SRC emacs-lisp (setq-default dotspacemacs-configuration-layers '(typescript)) #+END_SRC If you need formatting on save: #+BEGIN_SRC emacs-lisp (setq-default dotspacemacs-configuration-layers '( (typescript :variables typescript-fmt-on-save t))) #+END_SRC You can choose formatting tool: #+BEGIN_SRC emacs-lisp (setq-default dotspacemacs-configuration-layers '( (typescript :variables typescript-fmt-tool 'typescript-formatter))) #+END_SRC Default is 'tide . ** Notes This layer uses: - [[https://github.com/ananthakumaran/tide][tide]] - [[https://github.com/flycheck/flycheck][flycheck]] - [[https://github.com/vvakame/typescript-formatter][typescript-formatter]] - optional. *The tools use configuration files. You can learn more in their documentation.* Make sure to add [[https://github.com/Microsoft/TypeScript/wiki/tsconfig.json][tsconfig.json]] in the project root folder. tsserver mangles output sometimes [[https://github.com/Microsoft/TypeScript/issues/2758][issue - #2758]], which will result in json parse error. Try node version 0.12.x if you get this error. Send to playground requires browser. Currently tsserver doesn't pickup tsconfig.json file changes. You might need to restart server after editing it. * Configuration Tide comes with an embedded Typescript server, it is recommended to use the server intalled by =npm= instead. To do so set the variable =tide-tsserver-executable= to the path of the =tsserver= executable. For example: #+BEGIN_SRC emacs-lisp (setq-default dotspacemacs-configuration-layers '( (typescript :variables tide-tsserver-executable "/usr/local/bin/tsserver"))) #+END_SRC * Key bindings ** Typescript Major Mode | Key Binding | Description | |-------------+--------------------------------------------------------------| | ~SPC m =~ | reformat the buffer | | ~SPC m g b~ | jump back | | ~SPC m g g~ | jump to entity's definition | | ~SPC m g t~ | jump to entity's type definition | | ~SPC m g u~ | references | | ~SPC m h h~ | documentation at point | | ~SPC m r r~ | rename symbol | | ~SPC m s p~ | send selected region or current buffer to the web playground | | ~SPC m S r~ | restart server | ** Reference Major Mode | Key Binding | Description | |-------------+-------------------------| | ~C-j~ | find previous reference | | ~C-k~ | find next reference | | ~C-l~ | goto reference |