Interface generator for Visual Studio Code
Description
Interface generator is a VSCode Extension which creates an interface definition from a typescript class. Supports import statements, comments, public properties and methods, generics and optional.
Given class:
export class ExtendsOnly<XY, TG extends string> extends ABC implements DEF {
public NumberProperty: number = 2;
OptionalStringProperty?: string;
}
Since interfaces can not implement anything, implements DEF
is omitted.
Generated interface
export interface IExtendsOnly<XY, TG extends string> extends ABC {
NumberProperty: number;
OptionalStringProperty?: string;
}
data:image/s3,"s3://crabby-images/9021c/9021cde984be9739f8a49f464b8412daa0f89d06" alt="dotup-vscode-interface-generator Video"
Installation
You can browse and install extensions from within VS Code. Press Ctrl+P
and narrow down the list commands by typing ext install dotup-vscode-interface-generator
.
https://marketplace.visualstudio.com/items?itemName=dotup.dotup-vscode-interface-generator
Usage
1. Open a typescript file with one or more class definitions.
data:image/s3,"s3://crabby-images/41fc1/41fc1d2564038ee53ff8ff2fa36e3f2b02b2378b" alt="dotup-vscode-interface-generator Screenshot"
2. Press Ctrl+Shift+P
to see all commands and start typing Generate interface
and hit Enter
.
data:image/s3,"s3://crabby-images/1d925/1d925b0aead382da59f528a29cf3d056565f43ee" alt="dotup-vscode-interface-generator Screenshot"
The extension creates a new file in the same folder as the source file.
The new file has the name of the source file prefixed with I
.
Existing files will be overwritten!
data:image/s3,"s3://crabby-images/30cc6/30cc6649debaa6f6ee9a2a5ba42a6624cc7caa25" alt="dotup-vscode-interface-generator Screenshot"
Release Notes
1.0.15
Fixes/Features:
Release Notes
1.0.14
Fixes/Features:
- Explorer context menu "Generate interface"
- Error handling
1.0.13
Fixes/Features:
1.0.12
Fixes/Features:
1.0.11
Fixes/Features:
- take over comments ( For classes, methods and properties )
1.0.10
Fixes/Features:
- Readme: pictures not shown.
- Readme: Wrong 'Generate interface' example
- Icon added
- dependencies missed
- Wrong target path on Multi-root Workspaces
- prefix on interface name was missing
- video added
TODO:
- take over comments ( For classes, methods and properties )
Enjoy!