0.1.3 #4

Merged
Thilawyn merged 74 commits from next into master 2024-03-24 22:24:25 +01:00
3 changed files with 27 additions and 17 deletions
Showing only changes of commit 8c525f0968 - Show all commits

View File

@@ -1,7 +1,7 @@
import { dejsonifyBigIntSchema, jsonifyBigIntSchema } from "./bigint" import { dejsonifyBigIntSchema, jsonifyBigIntSchema } from "./bigint"
import { dejsonifyDateSchema, jsonifyDateSchema } from "./date" import { dejsonifyDateSchema, jsonifyDateSchema } from "./date"
import { dejsonifyDecimalSchema, jsonifyDecimalSchema } from "./decimal" import { dejsonifyDecimalSchema, jsonifyDecimalSchema } from "./decimal"
import { jsonifyOption } from "./option" import { dejsonifyOption, jsonifyOption } from "./option"
export const jsonify = { export const jsonify = {
@@ -15,4 +15,5 @@ export const dejsonify = {
bigint: dejsonifyBigIntSchema, bigint: dejsonifyBigIntSchema,
date: dejsonifyDateSchema, date: dejsonifyDateSchema,
decimal: dejsonifyDecimalSchema, decimal: dejsonifyDecimalSchema,
option: dejsonifyOption,
} as const } as const

View File

@@ -1,3 +1,11 @@
export * from "./decimal" import { decimal } from "./decimal"
export * from "./effect" import { effect } from "./effect"
export * from "./jsonified" import { dejsonify, jsonify } from "./jsonified"
export const s = {
decimal,
effect,
jsonify,
dejsonify,
} as const

View File

@@ -2,16 +2,15 @@ import { Implements } from "@thilawyn/traitify-ts"
import { Option } from "effect" import { Option } from "effect"
import { z } from "zod" import { z } from "zod"
import { ZodSchemaClass } from "./ZodSchemaClass" import { ZodSchemaClass } from "./ZodSchemaClass"
import { jsonify } from "./schema/jsonified" import { dejsonify, jsonify } from "./schema/jsonified"
import { jsonifyBigIntSchema } from "./schema/jsonified/bigint" import { s } from "./schema/lib"
import { effect } from "./schema/lib"
import { MobXObservableZodSchemaObject } from "./traits/MobXObservableZodSchemaObject" import { MobXObservableZodSchemaObject } from "./traits/MobXObservableZodSchemaObject"
const userExp = ZodSchemaClass( const userExp = ZodSchemaClass(
z.object({ z.object({
/** User ID */ /** User ID */
id: effect.option.option(z.bigint()).default(Option.none()), id: s.effect.option.option(z.bigint()).default(Option.none()),
/** Username */ /** Username */
name: z.string(), name: z.string(),
@@ -31,22 +30,24 @@ const userInstEffect = User.createEffect({ id: Option.some(1n), name: "User" })
const jsonifiedBigIntOption = jsonify.option.option( const jsonifiedBigIntOption = jsonify.option.option(
effect.option.option(z.bigint()), s.effect.option.option(z.bigint()),
jsonifyBigIntSchema, s.jsonify.bigint,
) )
type T1 = z.output<typeof jsonifiedBigIntOption>
const jsonifiedBigIntOptionSome = jsonify.option.some( const jsonifiedBigIntOptionSome = jsonify.option.some(
effect.option.some(z.bigint()), s.effect.option.some(z.bigint()),
jsonifyBigIntSchema, s.jsonify.bigint,
) )
type T2 = z.output<typeof jsonifiedBigIntOptionSome> const dejsonifiedBigIntOptionSome = dejsonify.option.some(
s.effect.option.some(z.bigint()),
s.dejsonify.bigint,
)
type T2 = z.output<typeof dejsonifiedBigIntOptionSome>
const jsonifiedBigIntOptionNone = jsonify.option.none( const jsonifiedBigIntOptionNone = jsonify.option.none(
effect.option.none(z.bigint()), s.effect.option.none(z.bigint()),
jsonifyBigIntSchema, s.jsonify.bigint,
) )
type T3 = z.output<typeof jsonifiedBigIntOptionNone>
// const jsonifiedUserExp = JsonifiedZodSchemaClass(User, { // const jsonifiedUserExp = JsonifiedZodSchemaClass(User, {