This commit is contained in:
@@ -2,8 +2,9 @@ import { QueryContext } from "@/query/reffuse"
|
||||
import { Uuid4Query } from "@/query/services"
|
||||
import { Uuid4QueryService } from "@/query/views/Uuid4QueryService"
|
||||
import { R } from "@/reffuse"
|
||||
import { HttpClient } from "@effect/platform"
|
||||
import { createFileRoute } from "@tanstack/react-router"
|
||||
import { Layer } from "effect"
|
||||
import { Console, Effect, Schema } from "effect"
|
||||
import { useMemo } from "react"
|
||||
|
||||
|
||||
@@ -12,12 +13,26 @@ export const Route = createFileRoute("/query/service")({
|
||||
})
|
||||
|
||||
function RouteComponent() {
|
||||
const context = R.useLayer()
|
||||
// const context = R.useLayer()
|
||||
|
||||
const layer = useMemo(() => Layer.empty.pipe(
|
||||
Layer.provideMerge(Uuid4Query.Uuid4QueryLive),
|
||||
Layer.provide(context),
|
||||
), [context])
|
||||
// const layer = useMemo(() => Layer.empty.pipe(
|
||||
// Layer.provideMerge(Uuid4Query.Uuid4QueryLive),
|
||||
// Layer.provide(context),
|
||||
// ), [context])
|
||||
|
||||
const query = R.useQuery({
|
||||
key: ["uuid4", 10],
|
||||
query: () => Console.log(`Querying 10 IDs...`).pipe(
|
||||
Effect.andThen(Effect.sleep("500 millis")),
|
||||
Effect.andThen(HttpClient.get(`https://www.uuidtools.com/api/generate/v4/count/10`)),
|
||||
HttpClient.withTracerPropagation(false),
|
||||
Effect.flatMap(res => res.json),
|
||||
Effect.flatMap(Schema.decodeUnknown(Uuid4Query.Result)),
|
||||
Effect.scoped,
|
||||
),
|
||||
})
|
||||
|
||||
const layer = useMemo(() => query.layer(Uuid4Query.Uuid4Query), [query])
|
||||
|
||||
return (
|
||||
<QueryContext.Provider layer={layer}>
|
||||
|
||||
Reference in New Issue
Block a user