From 33174296b34cc147e92f223b5fbf18590f5a166f Mon Sep 17 00:00:00 2001 From: Kevin De Porre Date: Wed, 6 Dec 2023 16:16:26 +0100 Subject: [PATCH] Fix type issue with zod and Prisma's XOR by introducing a dirty type cast on the problematic schemas. --- .../contentWriters/writeOutputObjectType.ts | 22 +++++++++++++++++-- .../writeSingleFileArgTypeStatements.ts | 3 ++- 2 files changed, 22 insertions(+), 3 deletions(-) diff --git a/generator/src/functions/contentWriters/writeOutputObjectType.ts b/generator/src/functions/contentWriters/writeOutputObjectType.ts index 46ce329e36..522b6d3f5d 100644 --- a/generator/src/functions/contentWriters/writeOutputObjectType.ts +++ b/generator/src/functions/contentWriters/writeOutputObjectType.ts @@ -1,8 +1,19 @@ import { writeSelect } from './writeSelect' import { writeNonScalarType, writeScalarType, writeSpecialType } from '..' -import { ExtendedDMMFSchemaField } from '../../classes' +import { ExtendedDMMF, ExtendedDMMFSchemaField } from '../../classes' import { type ContentWriterOptions } from '../../types' +function modelHasRelation( + model: ExtendedDMMFSchemaField['modelType'], + dmmf: ExtendedDMMF +): boolean { + if (typeof model === 'string') { + const maybeModel = dmmf.datamodel.models.find((m) => m.name === model) + return maybeModel?.hasRelationFields ?? false + } + return false +} + export const writeOutputObjectType = ( { fileWriter, dmmf, getSingleFileContent = false }: ContentWriterOptions, field: ExtendedDMMFSchemaField @@ -120,7 +131,14 @@ export const writeOutputObjectType = ( writer.newLine() }) }) - .write(`).strict()`) + .write(`).strict() `) + // There is a typing bug that occurs only with models that have relations. + // a dirty fix here is to typecast the value to the expected type: + // cf. https://github.com/chrishoermann/zod-prisma-types/issues/98#issuecomment-1800112669 + .conditionalWrite( + modelHasRelation(field.modelType, dmmf), + `as ${field.customArgType}` + ) if (useMultipleFiles && !getSingleFileContent) { writer.blankLine().writeLine(`export default ${field.argName}Schema;`) diff --git a/generator/src/functions/writeSingleFileArgTypeStatements.ts b/generator/src/functions/writeSingleFileArgTypeStatements.ts index 5c859a15bc..c17834fd82 100644 --- a/generator/src/functions/writeSingleFileArgTypeStatements.ts +++ b/generator/src/functions/writeSingleFileArgTypeStatements.ts @@ -15,7 +15,8 @@ export const writeSingleFileArgTypeStatements: WriteStatements = ( fileWriter.writeHeading(`ARGS`, 'FAT') - dmmf.schema.outputObjectTypes.argTypes.forEach((outputType) => { + const types = dmmf.schema.outputObjectTypes + types.argTypes.forEach((outputType) => { outputType.prismaActionFields.forEach((field) => { writeOutputObjectType({ dmmf, fileWriter }, field) })