Compare commits
6 Commits
next
...
696976b52f
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
696976b52f | ||
|
|
67bf12d7a9 | ||
|
|
a6ef4defe6 | ||
|
|
9ee50bfd19 | ||
|
|
7b3ed49369 | ||
|
|
9348178b0f |
@@ -71,6 +71,7 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@effect/schema": "^0.71.1",
|
"@effect/schema": "^0.71.1",
|
||||||
|
"@prisma/studio-server": "^0.502.0",
|
||||||
"@types/jsonwebtoken": "^9.0.6",
|
"@types/jsonwebtoken": "^9.0.6",
|
||||||
"bun-types": "^1.1.26",
|
"bun-types": "^1.1.26",
|
||||||
"effect": "^3.6.5",
|
"effect": "^3.6.5",
|
||||||
|
|||||||
29
src/Layers/PrismaStudioRoute.ts
Normal file
29
src/Layers/PrismaStudioRoute.ts
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
// import { StudioServer } from "@prisma/studio-server"
|
||||||
|
// import { Config, Effect, Layer } from "effect"
|
||||||
|
|
||||||
|
|
||||||
|
// export const PrismaStudioRouteLive = ({
|
||||||
|
// httpPort = Config.succeed(5555),
|
||||||
|
// schemaPath = Config.succeed(""),
|
||||||
|
// schemaText = Config.succeed(""),
|
||||||
|
// }: {
|
||||||
|
// httpPort: Config.Config<number>
|
||||||
|
// schemaPath: Config.Config<string>
|
||||||
|
// schemaText: Config.Config<string>
|
||||||
|
// }) =>
|
||||||
|
// Layer.effectDiscard(Effect.gen(function*() {
|
||||||
|
|
||||||
|
// return Effect.acquireRelease(
|
||||||
|
// Effect.gen(function*() {
|
||||||
|
// const server = new StudioServer({
|
||||||
|
// port: yield* httpPort,
|
||||||
|
// schemaPath: yield* schemaPath,
|
||||||
|
// schemaText: yield* schemaText,
|
||||||
|
// })
|
||||||
|
// }),
|
||||||
|
|
||||||
|
// () => Effect.gen(function*() {
|
||||||
|
|
||||||
|
// }),
|
||||||
|
// )
|
||||||
|
// }))
|
||||||
@@ -8,19 +8,19 @@ interface ObservableClassSelf {
|
|||||||
readonly fields: { readonly [K in keyof Schema.Struct.Fields]: Schema.Struct.Fields[K] }
|
readonly fields: { readonly [K in keyof Schema.Struct.Fields]: Schema.Struct.Fields[K] }
|
||||||
}
|
}
|
||||||
|
|
||||||
export const ObservableClass = <Self extends ObservableClassSelf>(
|
interface ObservableClassOptions extends Omit<CreateObservableOptions, "proxy"> {}
|
||||||
self: Self,
|
|
||||||
options?: Omit<CreateObservableOptions, "proxy">,
|
|
||||||
) =>
|
|
||||||
class Observable extends self {
|
|
||||||
declare ["constructor"]: typeof Observable
|
|
||||||
|
|
||||||
constructor(...args: any[]) {
|
export const ObservableClass = (options?: ObservableClassOptions) =>
|
||||||
super(...args)
|
<Self extends ObservableClassSelf>(self: Self) =>
|
||||||
|
class Observable extends self {
|
||||||
|
declare ["constructor"]: typeof Observable
|
||||||
|
|
||||||
makeObservable(this,
|
constructor(...args: any[]) {
|
||||||
mapValues(this.constructor.fields, () => observable),
|
super(...args)
|
||||||
options,
|
|
||||||
)
|
makeObservable(this,
|
||||||
}
|
mapValues(this.constructor.fields, () => observable),
|
||||||
} as Self
|
options,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
} as Self
|
||||||
|
|||||||
@@ -10,4 +10,4 @@ export const toJsonifiable = <
|
|||||||
jsonifiableSchema: Schema.Schema<JsonifiableA, JsonifiableI, JsonifiableR>
|
jsonifiableSchema: Schema.Schema<JsonifiableA, JsonifiableI, JsonifiableR>
|
||||||
) =>
|
) =>
|
||||||
<A, R>(decodedSchema: Schema.Schema<A, JsonifiableA, R>) =>
|
<A, R>(decodedSchema: Schema.Schema<A, JsonifiableA, R>) =>
|
||||||
Schema.compose(jsonifiableSchema, decodedSchema)
|
Schema.compose(jsonifiableSchema, decodedSchema, { strict: true })
|
||||||
|
|||||||
20
src/tests.ts
20
src/tests.ts
@@ -1,5 +1,5 @@
|
|||||||
import { Schema as S } from "@effect/schema"
|
import { Schema as S } from "@effect/schema"
|
||||||
import { reaction, runInAction } from "mobx"
|
import { computed, makeObservable, reaction, runInAction } from "mobx"
|
||||||
import type { Simplify } from "type-fest"
|
import type { Simplify } from "type-fest"
|
||||||
import { MutableTaggedClass, toJsonifiable } from "./Schema"
|
import { MutableTaggedClass, toJsonifiable } from "./Schema"
|
||||||
import { ObservableClass } from "./Schema/MobX"
|
import { ObservableClass } from "./Schema/MobX"
|
||||||
@@ -18,12 +18,24 @@ type TestB = {
|
|||||||
type Merged = Simplify<ExtendAll<[TestA, TestB]>>
|
type Merged = Simplify<ExtendAll<[TestA, TestB]>>
|
||||||
|
|
||||||
|
|
||||||
class User extends MutableTaggedClass<User>()("User", {
|
|
||||||
|
const UserSchema = MutableTaggedClass<User>()("User", {
|
||||||
id: S.BigIntFromSelf,
|
id: S.BigIntFromSelf,
|
||||||
role: S.Union(S.Literal("BasicUser"), S.Literal("Admin")),
|
role: S.Union(S.Literal("BasicUser"), S.Literal("Admin")),
|
||||||
}).pipe(
|
}).pipe(
|
||||||
ObservableClass
|
ObservableClass()
|
||||||
) {}
|
)
|
||||||
|
|
||||||
|
class User extends UserSchema {
|
||||||
|
constructor(...args: ConstructorParameters<typeof UserSchema>) {
|
||||||
|
super(...args)
|
||||||
|
makeObservable(this, { idAsString: computed })
|
||||||
|
}
|
||||||
|
|
||||||
|
get idAsString() {
|
||||||
|
return this.id.toString()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const JsonifiableUser = User.pipe(
|
const JsonifiableUser = User.pipe(
|
||||||
toJsonifiable(S.Struct({
|
toJsonifiable(S.Struct({
|
||||||
|
|||||||
Reference in New Issue
Block a user