0.1.2 #3

Merged
Thilawyn merged 136 commits from next into master 2024-03-11 19:44:21 +01:00
3 changed files with 128 additions and 18 deletions
Showing only changes of commit 338c750a4b - Show all commits

View File

@@ -1,6 +1,8 @@
import { Class as ConcreteClass, HasRequiredKeys } from "type-fest" import { Effect } from "effect"
import { AbstractClass, Class as ConcreteClass, HasRequiredKeys, Opaque } from "type-fest"
import { z } from "zod" import { z } from "zod"
import { Class, ClassType } from "./util" import { DefinedDefaultValuesTag } from "."
import { Class, ClassType, StaticMembers } from "./util"
export type NewZodSchemaInstanceInput< export type NewZodSchemaInstanceInput<
@@ -22,8 +24,23 @@ export type NewZodSchemaInstanceArgs<Input extends object> =
: [] | [values: Input, ...args: ParseParamsArgs] : [] | [values: Input, ...args: ParseParamsArgs]
type ExtendZodSchemaClass<
Parent extends AbstractClass<any>,
Self extends AbstractClass<any>,
> = (
AbstractClass<
Omit<InstanceType<Parent>, keyof InstanceType<DefaultZodSchemaClass>> &
InstanceType<Self>,
ConstructorParameters<Self>
> &
Omit<Parent, keyof DefaultZodSchemaClass> &
StaticMembers<Self>
)
export type TZodSchemaClass< export type TZodSchemaClass<
Schema extends z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values>,
SchemaT extends z.ZodRawShape, SchemaT extends z.ZodRawShape,
SchemaUnknownKeys extends z.UnknownKeysParam, SchemaUnknownKeys extends z.UnknownKeysParam,
SchemaCatchall extends z.ZodTypeAny, SchemaCatchall extends z.ZodTypeAny,
@@ -38,7 +55,7 @@ export type TZodSchemaClass<
Values, Values,
[values: Values] [values: Values]
> & { > & {
readonly schema: Schema readonly schema: z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values>
readonly defaultValues: DefaultValues readonly defaultValues: DefaultValues
instantiate<Self extends ConcreteClass<any>>( instantiate<Self extends ConcreteClass<any>>(
@@ -60,12 +77,48 @@ export type TZodSchemaClass<
...[values, params]: NewZodSchemaInstanceArgs< ...[values, params]: NewZodSchemaInstanceArgs<
NewZodSchemaInstanceInput<Values, DefaultValues> NewZodSchemaInstanceInput<Values, DefaultValues>
> >
): Promise<InstanceType<Self>> ): Effect.Effect<never, z.ZodError<Values>, Values>
extend< extend<
Parent Parent extends AbstractClass<any>,
ExtendedSchemaT extends z.ZodRawShape,
ExtendedSchemaUnknownKeys extends z.UnknownKeysParam,
ExtendedSchemaCatchall extends z.ZodTypeAny,
ExtendedValues extends Values,
ExtendedDefaultValues extends Partial<ExtendedValues>,
>( >(
this: Parent this: Parent,
): Parent
props: {
schema: (props: {
schema: z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values>
shape: SchemaT
}) => z.ZodObject<ExtendedSchemaT, ExtendedSchemaUnknownKeys, ExtendedSchemaCatchall, ExtendedValues, ExtendedValues>
defaultValues: (defaultValues: DefaultValues) => Opaque<ExtendedDefaultValues, DefinedDefaultValuesTag>
},
): ExtendZodSchemaClass<
Parent,
TZodSchemaClass<
ExtendedSchemaT,
ExtendedSchemaUnknownKeys,
ExtendedSchemaCatchall,
ExtendedValues,
ExtendedDefaultValues
>
>
} }
) )
export type DefaultZodSchemaClass = TZodSchemaClass<
z.ZodRawShape,
z.UnknownKeysParam,
z.ZodTypeAny,
{},
{}
>

View File

@@ -1,7 +1,8 @@
import { Effect, pipe } from "effect"
import { AbstractClass, Class as ConcreteClass, Opaque } from "type-fest" import { AbstractClass, Class as ConcreteClass, Opaque } from "type-fest"
import { z } from "zod" import { z } from "zod"
import { DefinedDefaultValuesTag, NewZodSchemaInstanceArgs, NewZodSchemaInstanceInput, TZodSchemaClass } from "." import { DefinedDefaultValuesTag, NewZodSchemaInstanceArgs, NewZodSchemaInstanceInput, TZodSchemaClass } from "."
import { StaticMembers } from "./util" import { StaticMembers, parseZodTypeEffect } from "./util"
type ExtendableClass = AbstractClass<any, []> & { type ExtendableClass = AbstractClass<any, []> & {
@@ -12,7 +13,6 @@ type ExtendableClass = AbstractClass<any, []> & {
export function ZodSchemaClassOf< export function ZodSchemaClassOf<
Parent extends ExtendableClass, Parent extends ExtendableClass,
Schema extends z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values>,
SchemaT extends z.ZodRawShape, SchemaT extends z.ZodRawShape,
SchemaUnknownKeys extends z.UnknownKeysParam, SchemaUnknownKeys extends z.UnknownKeysParam,
SchemaCatchall extends z.ZodTypeAny, SchemaCatchall extends z.ZodTypeAny,
@@ -23,7 +23,7 @@ export function ZodSchemaClassOf<
of: Parent, of: Parent,
{ schema, defaultValues }: { { schema, defaultValues }: {
schema: Schema | z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values> schema: z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values>
defaultValues: Opaque<DefaultValues, DefinedDefaultValuesTag> defaultValues: Opaque<DefaultValues, DefinedDefaultValuesTag>
}, },
) { ) {
@@ -34,7 +34,6 @@ export function ZodSchemaClassOf<
) )
type TZodSchemaClassImpl = TZodSchemaClass< type TZodSchemaClassImpl = TZodSchemaClass<
Schema,
SchemaT, SchemaT,
SchemaUnknownKeys, SchemaUnknownKeys,
SchemaCatchall, SchemaCatchall,
@@ -52,7 +51,7 @@ export function ZodSchemaClassOf<
Object.assign(this, values) Object.assign(this, values)
} }
static async instantiate( static instantiate(
...[values, params]: NewZodSchemaInstanceArgs< ...[values, params]: NewZodSchemaInstanceArgs<
NewZodSchemaInstanceInput<Values, DefaultValues> NewZodSchemaInstanceInput<Values, DefaultValues>
> >
@@ -71,6 +70,52 @@ export function ZodSchemaClassOf<
await this.schema.parseAsync({ ...this.defaultValues, ...values }, params) await this.schema.parseAsync({ ...this.defaultValues, ...values }, params)
) )
} }
static instantiateEffect(
...[values, params]: NewZodSchemaInstanceArgs<
NewZodSchemaInstanceInput<Values, DefaultValues>
>
) {
return pipe(
parseZodTypeEffect(
this.schema,
{ ...this.defaultValues, ...values },
params,
),
Effect.map(values => new this(values)),
)
}
static extend<
ExtendedSchemaT extends z.ZodRawShape,
ExtendedSchemaUnknownKeys extends z.UnknownKeysParam,
ExtendedSchemaCatchall extends z.ZodTypeAny,
ExtendedValues extends Values,
ExtendedDefaultValues extends Partial<ExtendedValues>,
>(
props: {
schema: (props: {
schema: z.ZodObject<SchemaT, SchemaUnknownKeys, SchemaCatchall, Values, Values>
shape: SchemaT
}) => z.ZodObject<ExtendedSchemaT, ExtendedSchemaUnknownKeys, ExtendedSchemaCatchall, ExtendedValues, ExtendedValues>
defaultValues: (defaultValues: DefaultValues) => Opaque<ExtendedDefaultValues, DefinedDefaultValuesTag>
},
) {
const schema = props.schema({
schema: this.schema,
shape: this.schema.shape,
})
const defaultValues = props.defaultValues(this.defaultValues)
return class extends (this as unknown as ConcreteClass<any, []>) {
static readonly schema = schema
static readonly defaultValues = defaultValues
}
}
} as unknown as ( } as unknown as (
Class< Class<
InstanceType<Parent> & InstanceType<Parent> &

View File

@@ -14,12 +14,24 @@ class Test extends ZodSchemaClassOf(Root, {
defaultValues: defineDefaultValues({ id: -1n }), defaultValues: defineDefaultValues({ id: -1n }),
}) {} }) {}
Test.defaultValues Test.defaultValues
const inst = await Test.instantiatePromise({ id: 1n, name: "" }) const inst = await Test.instantiatePromise({ id: 1n, name: "" })
// Test.extend()
console.log(inst) class SubTest extends Test.extend({
schema: ({ schema }) => schema.extend({
prout: z.string()
}),
class ChildTest extends Test {} defaultValues: defaultValues => defineDefaultValues({
...defaultValues
}),
}) {}
ChildTest.instantiate({ name: "" }) const subInst = await SubTest.instantiatePromise({ name: "", prout: "" })
console.log(subInst)
// class ChildTest extends Test {}
// ChildTest.instantiate({ name: "" })