0.6.0 • Published 6 years ago
babel-plugin-flow-to-typescript v0.6.0
babel-plugin-flow-to-typescript
Babel plugin to convert Flow code into TypeScript
How to use
$ npm install -g @babel/cli @babel/core
$ npm install babel-plugin-flow-to-typescript
# you must use babel@^7.x.x
$ babel --version
7.4.4 (@babel/core 7.4.5)
$ babel --plugins babel-plugin-flow-to-typescript ${SRC_FLOW_FILE} -o ${DEST_TS_FILE}Implementation status
| Supported? | Syntax | Flow | TypeScript |
|---|---|---|---|
| ✅ | Maybe type | let a:?number | let a: number \| null \| undefined |
| ✅ | Void type | void | void |
| ✅ | Object type | Object | object |
| ✅ | Mixed type | mixed | unknown |
| ✅ | Function type | (A, B) => C | (x1: A, x2: B) => C |
| ✅ | Exact type | {\| a: A \|} | { a: A } |
| ✅ | Indexers | { [A]: B } | { [a: A]: B } |
| ✅ | Existential type | Map<*, *> | Map<any, any> |
| ✅ | Opaque types | opaque type A = B | type A = B |
| ✅ | Variance | interface A { +b: B, -c: C } | interface A { readonly b: B, c: C } |
| ✅ | Type parameter bounds | function f<A: string>(a:A){} | function f<A extends string>(a:A){} |
| ✅ | Cast | (a: A) | (a as A) |
| ✅ | type/typeof import | import type A from 'module' | import A from 'module' |
| ✅ | \$Keys | $Keys<X> | keyof X |
| ✅ | \$Values | $Values<X> | X[keyof X] |
| ✅ | \$ReadOnly | $Readonly<X> | Readonly<X> |
| ✅ | \$Exact | $Exact<X> | X |
| ✅ | \$Diff | $Diff<X, Y> | Pick<X, Exclude<keyof X, keyof Y>> |
| ✅ | \$PropertyType | $PropertyType<T, k> | T[k] |
| ✅ | \$ElementType | $ElementType<T, k> | T[k] |
| ✅ | $Shape | $Shape<T> | Partial<T> |
| ✅ | Class | Class<T> | typeof T |
| ✅ | typeof operator | typeof foo | typeof foo |
| ✅ | JSX | - | - |
| ✅ | Tuple type | [number, string] | [number, string] |
| ✅ | Type alias | type A = string | type A = string |
| ✅ | Flow Ignore | $FlowFixMe | any |
| ✅ | Interfaces | interface X { +prop: string } | interface X { readonly prop: string } |
| ✅ | Optional Members | a?.b | ... |
| ✅ | Declare functions | declare function x(false): true; | function x(x0: false): true; |
| ✅ | Declare Class | ... | ... |