flowts
v0.16.2
Published
Utility script to convert flow typed code to typescript
Downloads
9,661
Readme
Flow to Typescript
Usage:
npm install -g flowts
Usage: flowts [options] ./path/to/project
Flow to TypeScript migration tool
Options:
-V, --version output the version number
-R, --no-recast use babel generator instead of recast
-P, --no-prettier do not run prettier on converted code
--no-allow-js convert all JS files to TypeScript(including without Flow)
--interactive-rename Wait for interactive confirmation after renaming, before writing converted code
(allowing to have separate commit to better preserve file history) (default: false)
-i, --include <includeGlob> Glob expression of files to include,
default: "**/*.{js,mjs,jsx,js.flow}" (default: "**/*.{js,mjs,jsx,js.flow}")
-x, --exclude <excludeGlob> Additional excludes glob expression (by default node_modules
and files from .gitignore is excluded) (default: "**/node_modules/**")
-h, --help display help for command
How it works
- Convert source code using: https://github.com/zxbodya/flowts/tree/master/packages/babel-plugin-flow-to-typescript
- Do some additional fixes for types embedded in flow library (for example react types are somewhat different from typescript version)
- Prints code using recast (https://github.com/benjamn/recast), so most of the formatting is preserved.
- Because not all formatting can be preserved - it also re-formats code using prettier (assumption is that converted codebase is using it, and there is configured in standard way, like having
.prettierrc
). Also be sure you already have prettier 2.0 (it needed for TypeScript 3.8) - Before writing converted file - script verifies that there are no changes other than type annotations (all errors are logged - so, be sure to check logs and to adjustments accordingly)
Project priorities
- Only type annotation should be changed, so code after migration is in "working" state
- Type information should be preserved as much as possible
- When possible formatting and comments should be preserved
Cavearts
There might be unexpected formatting changes, or bugs related to using recast - it is good, but there can be bugs…
Rarely, but sometimes:
- there might be unexpected formatting changes
- some comments might be removed