Easy Code Generator Site
// ✓ user-service.ts (YOUR CODE - never overwritten) import UserServiceBase from './user-service.base';
In the modern development landscape, the phrase "don't repeat yourself" (DRY) is practically a mantra. Yet, every day, millions of developers write the same CRUD operations, the same API endpoints, and the same data validation logic. We solve this partially with copy-paste, partially with snippets, and partially with libraries. But there is a more powerful, often underutilized tool: the Easy Code Generator .
// ✓ user-service.base.ts (GENERATED - feel free to overwrite) export abstract class UserServiceBase async createUser(data: UserCreateInput): Promise<User> ... easy code generator
This pattern—generating a base class and inheriting from it—allows you to regenerate fearlessly forever. You don't need a complex infrastructure to start.
// ✗ GENERATED - DO NOT EDIT (You will edit it anyway) class UserService async createUser(data) ... // generated async sendWelcomeEmail(data) ... // CUSTOM - where does this go? // ✓ user-service
entities: - name: User fields: - name: id, type: number - name: email, type: string, unique: true - name: createdAt, type: Date - name: Product fields: - name: sku, type: string, required: true - name: price, type: number, min: 0 Your template ( model.tmpl ) could be:
export class entity.name % for field in entity.fields % field.name : field.type ; % endfor % constructor(data: Partial< entity.name >) Object.assign(this, data); But there is a more powerful, often underutilized
Do not generate entire files. Generate that your application imports.
Stop copying and pasting. Start generating.
export class UserService extends UserServiceBase // Your custom logic here async sendWelcomeEmail(user: User) // custom implementation