@rxap/schematics-ts-morph
Version:
This package provides utilities for manipulating TypeScript code using ts-morph, particularly for Angular and NestJS projects. It offers functions to add, coerce, and modify code elements like classes, methods, decorators, and imports. The package also in
14 lines (13 loc) • 1.09 kB
TypeScript
import { Rule } from '@angular-devkit/schematics';
import { ClassDeclaration, SourceFile } from 'ts-morph';
import { TsMorphAngularProjectTransformOptions } from '../ts-morph-transform';
import { AbstractControl } from '../types/abstract-control';
export interface CoerceFormDefinitionOptions extends TsMorphAngularProjectTransformOptions {
controlList?: ReadonlyArray<AbstractControl>;
name: string;
tsMorphTransform?: (sourceFile: SourceFile, classDeclaration: ClassDeclaration) => void;
coerceFormType?: (sourceFile: SourceFile, classDeclaration: ClassDeclaration, formTypeName: string, options: CoerceFormDefinitionOptions) => void;
coerceFormControls?: (sourceFile: SourceFile, classDeclaration: ClassDeclaration, formTypeName: string, options: CoerceFormDefinitionOptions) => void;
}
export declare function CoerceFormControls(sourceFile: SourceFile, classDeclaration: ClassDeclaration, formTypeName: string, { controlList }: CoerceFormDefinitionOptions): void;
export declare function CoerceFormDefinition(options: Readonly<CoerceFormDefinitionOptions>): Rule;