0.1.2 #3
@@ -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,
|
||||||
|
|
||||||
|
{},
|
||||||
|
{}
|
||||||
|
>
|
||||||
|
|||||||
@@ -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> &
|
||||||
|
|||||||
20
src/tests.ts
20
src/tests.ts
@@ -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: "" })
|
||||||
|
|||||||
Reference in New Issue
Block a user