@mainamiru/prisma-types-generator
v1.1.14
Published
Prisma Types Generator. Prisma Interface Generator
Maintainers
Readme
Prisma Types Generator
Prisma
Prisma is Database ORM Library for Node.js, Typescript.
Prisma basically generate each models type definition defined in schema.prisma.
This is Prisma's basic way of doing things, and I love this approach.
So I created a simple tool that generates a typescript file based on schema.prisma. The generated types are formatted with prettier, using the user's prettier config file if present.
This will reduce the effort to define types directly while using the same single source of truth (schema.prisma)
The Prisma JS Client returns objects that does not contain the model's relational fields. The Generator can create two separate files per model, one that matches the Prisma Js Client's interfaces, and one that contains only the relational fields.
Usage
Install
bun add --dev @mainamiru/prisma-types-generator yarn add --dev @mainamiru/prisma-types-generator npm install --save-dev @mainamiru/prisma-types-generatorDefine Generator in
schema.prismagenerator prismaTypesGenerator { provider = "prisma-types-generator" modelSuffix = "Model" prettier = "false" }And finally generate your Prisma schema:npx prisma generateBy default that will output the Typescript interface definitions to a file called generated in your prisma folder, this can be changed by specifying the output option. As mentioned above, by default the generated types will be type compatible with the Prisma client types. If you instead want to generate types matching the JSON. stringify-ed versions of your models, you will need to change some of the options.
Options
| Option | Type | Default | Description |
| ----------- | --------- | ------------- | ------------------------------------------------------------------------------------------------------------ |
| output | string | "generated" | The output location for the generated TypeScript. |
| modelSuffix | string | "Model" | Suffix to add to model types. |
| prettier | boolean | false | Formats the output using Prettier. Setting this to true requires that the prettier package is available. |
😎 done! Let's check out generated files.
if this models were defined in your prisma.schema file.
model User { id String @id @default(cuid()) name String @db.VarChar(30) image String? @db.VarChar(200) gender Gender @default(MALE) email String @unique @db.VarChar(50) mobile String @unique @db.VarChar(15) role UserRole @default(USER) password String @db.VarChar(200) created_at DateTime @default(now()) updated_at DateTime @updatedAt posts Post[] @@map("users") } model Post { id String @id @default(cuid()) title String @db.VarChar(100) image String? @db.VarChar(200) content String @db.VarChar(1000) published Boolean @default(true) authorId String @db.VarChar(100) created_at DateTime @default(now()) updated_at DateTime @updatedAt author User? @relation(fields: [authorId], references: [id]) @@map("posts") } enum Gender { MALE FEMALE } enum UserRole { USER ADMIN AUTHOR }then this types is generated in <PROJECTPATH>/generated. ( The generating path can be customized through _output option. )
// user.ts import { Gender, UserRole } from "./enums"; import { PostModel, PostCreateInput } from "./post"; export interface UserModel { id: string; name: string; image: string | null; gender: Gender; email: string; mobile: string; role: UserRole; password: string; created_at: Date; updated_at: Date; posts?: PostModel[]; } export interface UserCreateInput { id?: string; name: string; image?: string | null; gender?: Gender; email: string; mobile: string; role?: UserRole; password: string; created_at?: Date; updated_at?: Date; posts?: PostCreateInput[]; } export type UserUpdateInput = Partial<UserCreateInput>;// post.ts import { UserModel, UserCreateInput } from "./user"; export interface PostModel { id: string; title: string; image: string | null; content: string; published: boolean; authorId: string; created_at: Date; updated_at: Date; author?: UserModel; } export interface PostCreateInput { id?: string; title: string; image?: string | null; content: string; published?: boolean; authorId: string; created_at?: Date; updated_at?: Date; author?: UserCreateInput; } export type PostUpdateInput = Partial<PostCreateInput>;// index.ts export * from "./user"; export * from "./post";
How it works?
Prisma internally defines metadata as a dmmf object.
It is defined as an additional generator in the schema.prisma file and will operate in the prisma generate process.
Feature
- generate types/interfaces from prisma model definition
- Support Basic Type and Relation
FAQ
1. It's works with all javascript/typescript libary
You can use for all API payload response in React, React Native, Nextjs etc...
