
Product
Introducing Socket MCP for Claude Desktop
Add secure dependency scanning to Claude Desktop with Socket MCP, a one-click extension that keeps your coding conversations safe from malicious packages.
angular-formsbuilder-gen
Advanced tools
Auto Generate Forms Builder Files For Angualr 6+ Base On Swagger Generated Scheme
This NPM module generates build form class from an OpenApi, The generated classes follow the principles of Angular. The generated code is compatible with Angular 12+.
Most of angular developers takes time on writeing form group objects or use form builder to generated models based on
openapi scheme , which can take long time so I've decided to use formBuilder Helper class and wrote this tool to help
by auto generated formbuilder scripts for each model
If you want to install "angular-formsbuilder-gen" globally or just on your project
npm install -g ng-openapi-gen
npm install -g angular-formsbuilder-gen
Then If you want to use it first you need to create configuration file in root of your angular app let's call it 'swagger.json' which should contains following object
{
"$schema": "node_modules/ng-openapi-gen/ng-openapi-gen-schema.json",
"input": "https://localhost:44325/swagger/v1/swagger.json",
"output": "./src/app/api",
"ignoreUnusedModels": false,
"modelsPath": "./../api/models",
"formsOutput": "/src/app/forms"
"schemeFile": "E://swagger.json"
}
note this file will be used also for ng-openapi-gen tool Click here to know more about it in section "Configuration file and CLI arguments."
our tool cares only about properties "modelsPath, formsOutput, input"
scheme is loaded from local file instead of url even if url is set
models: path for generated models ng-openapi-gen
formsOutput: where should our tool generated formsbuilder classes
first we need to generated services and models by using ng-openapi-gen
Execute Following Command:
ng-openapi-gen -c swagger.json
Note: Make sure files are generated in "output" path defined in swagger.json
to generate angular you models formsbuilder classes
Execute Following Command:
ng-frmGenerator swagger.json
or you can use
ng-frmGenerator
only because default filename for configuration is "swagger.json"
following example is for simple user information
import { Injectable } from '@angular/core';
import { DatePipe } from '@angular/common';
import { FormControl, FormArray, FormGroup, FormBuilder, AbstractControl } from '@angular/forms';
import { IFormBuilder } from './IFormBuilder';
import { CustomerDto, UserAddressDto } from './../api/models';
import { UserAddressDtoFormBuilder } from './UserAddressDto';
import { oneOfValidator, guidValidator } from './CustomeValidators';
@Injectable({ providedIn: 'root' })
export class CustomerDtoFormBuilder implements IFormBuilder<CustomerDto> {
DatePipe: DatePipe = null as any;
DateFormat: string = 'yyyy-MM-dd';
form: FormGroup = null as any;
constructor(private fb: FormBuilder
, private UserAddressDtoFormBuilderSrvc: UserAddressDtoFormBuilder
) {
this.DatePipe = new DatePipe('en-US');
}
updateCulture(culture: string = 'en-US') {
this.DatePipe = new DatePipe(culture);
}
resetForm() {
this.form.reset();
}
buildForm(model: CustomerDto | null = null) {
this.form = this.fb.group({
userName: [ '' , Validators.compose([ Validators.required, Validators.minLength(1) ]) ],
password: [ '' , Validators.compose([ Validators.required ]) ],
addresses: [ this.UserAddressDtoFormBuilderSrvc.buildForm() ],
});
if (model != null) {
this.form.patchValue({ ...model });
}
return this.form;
}
get userNameCtrl(): FormControl {
return this.form.get('userName') as FormControl;
}
get userNameValueChanges$() {
return this.userNameCtrl?.valueChanges;
}
get passwordCtrl(): FormControl {
return this.form.get('password') as FormControl;
}
get passwordValueChanges$() {
return this.passwordCtrl?.valueChanges;
}
addressesArray(): FormArray {
return this.form.controls['addresses'] as FormArray;
}
addressesControls(): AbstractControl<any, any>[] {
return this.addressesArray().controls;
}
deleteAddressesByIndex(index: number): void {
this.addressesArray().removeAt(index);
}
addNewAddresses(model: UserAddressDtoFormBuilder | null = null): FormGroup<any> {
let frm = this.UserAddressDtoFormBuilderSrvc.buildForm(model);
this.addressesArray().push(frm);
return frm;
}
addNewaddresses(model: UserAddressDto | null = null): FormGroup<any> {
let frm = this.UserAddressDtoFormBuilderSrvc.buildForm(model);
this.addressesArray().push(frm);
return frm;
}
}
in this version I've made a refactor in core behaviour of generating the files in order to support basic validations defined in swagger.json document.
fix some issues which causes missing props in some models.
fix issue of build related to custome validator guidValidator
FAQs
Accelerate Angular Development with Auto Reactive Forms Builder Generator Based On Open API
The npm package angular-formsbuilder-gen receives a total of 2 weekly downloads. As such, angular-formsbuilder-gen popularity was classified as not popular.
We found that angular-formsbuilder-gen demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Add secure dependency scanning to Claude Desktop with Socket MCP, a one-click extension that keeps your coding conversations safe from malicious packages.
Product
Socket now supports Scala and Kotlin, bringing AI-powered threat detection to JVM projects with easy manifest generation and fast, accurate scans.
Application Security
/Security News
Socket CEO Feross Aboukhadijeh and a16z partner Joel de la Garza discuss vibe coding, AI-driven software development, and how the rise of LLMs, despite their risks, still points toward a more secure and innovative future.