@reffuse/extension-query 0.1.5 #16
@@ -10,11 +10,13 @@ export class Uuid4Query extends QueryService.Tag("Uuid4Query")<Uuid4Query,
|
|||||||
HttpClientError.HttpClientError | ParseResult.ParseError
|
HttpClientError.HttpClientError | ParseResult.ParseError
|
||||||
>() {}
|
>() {}
|
||||||
|
|
||||||
export const Uuid4QueryLive = QueryService.layer(Uuid4Query, Console.log("Querying...").pipe(
|
export const Uuid4QueryLive = QueryService.layer(Uuid4Query, {
|
||||||
|
query: Console.log("Querying...").pipe(
|
||||||
Effect.andThen(Effect.sleep("500 millis")),
|
Effect.andThen(Effect.sleep("500 millis")),
|
||||||
Effect.andThen(HttpClient.get("https://www.uuidtools.com/api/generate/v4")),
|
Effect.andThen(HttpClient.get("https://www.uuidtools.com/api/generate/v4")),
|
||||||
HttpClient.withTracerPropagation(false),
|
HttpClient.withTracerPropagation(false),
|
||||||
Effect.flatMap(res => res.json),
|
Effect.flatMap(res => res.json),
|
||||||
Effect.flatMap(Schema.decodeUnknown(Result)),
|
Effect.flatMap(Schema.decodeUnknown(Result)),
|
||||||
Effect.scoped,
|
Effect.scoped,
|
||||||
))
|
)
|
||||||
|
})
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ function RouteComponent() {
|
|||||||
const runSync = R.useRunSync()
|
const runSync = R.useRunSync()
|
||||||
|
|
||||||
const { state, refresh } = R.useQuery({
|
const { state, refresh } = R.useQuery({
|
||||||
effect: () => Console.log("Querying...").pipe(
|
query: () => Console.log("Querying...").pipe(
|
||||||
Effect.andThen(Effect.sleep("500 millis")),
|
Effect.andThen(Effect.sleep("500 millis")),
|
||||||
Effect.andThen(HttpClient.get("https://www.uuidtools.com/api/generate/v4")),
|
Effect.andThen(HttpClient.get("https://www.uuidtools.com/api/generate/v4")),
|
||||||
HttpClient.withTracerPropagation(false),
|
HttpClient.withTracerPropagation(false),
|
||||||
@@ -25,7 +25,7 @@ function RouteComponent() {
|
|||||||
Effect.flatMap(Schema.decodeUnknown(Result)),
|
Effect.flatMap(Schema.decodeUnknown(Result)),
|
||||||
Effect.scoped,
|
Effect.scoped,
|
||||||
),
|
),
|
||||||
deps: [],
|
key: [],
|
||||||
})
|
})
|
||||||
|
|
||||||
const [queryState] = R.useRefState(state)
|
const [queryState] = R.useRefState(state)
|
||||||
|
|||||||
@@ -7,8 +7,8 @@ import * as QueryRunner from "./QueryRunner.js"
|
|||||||
|
|
||||||
|
|
||||||
export interface UseQueryProps<A, E, R> {
|
export interface UseQueryProps<A, E, R> {
|
||||||
effect: () => Effect.Effect<A, E, R>
|
readonly query: () => Effect.Effect<A, E, R>
|
||||||
readonly deps: React.DependencyList
|
readonly key: React.DependencyList
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface UseQueryResult<A, E> {
|
export interface UseQueryResult<A, E> {
|
||||||
@@ -22,12 +22,14 @@ export const QueryExtension = ReffuseExtension.make(() => ({
|
|||||||
this: ReffuseHelpers.ReffuseHelpers<R>,
|
this: ReffuseHelpers.ReffuseHelpers<R>,
|
||||||
props: UseQueryProps<A, E, R>,
|
props: UseQueryProps<A, E, R>,
|
||||||
): UseQueryResult<A, E> {
|
): UseQueryResult<A, E> {
|
||||||
const runner = this.useMemo(() => QueryRunner.make(props.effect()), [])
|
const runner = this.useMemo(() => QueryRunner.make({
|
||||||
|
query: props.query()
|
||||||
|
}), [])
|
||||||
|
|
||||||
this.useEffect(() => Effect.addFinalizer(() => runner.forkInterrupt).pipe(
|
this.useEffect(() => Effect.addFinalizer(() => runner.forkInterrupt).pipe(
|
||||||
Effect.andThen(Ref.set(runner.queryRef, props.effect())),
|
Effect.andThen(Ref.set(runner.queryRef, props.query())),
|
||||||
Effect.andThen(runner.forkFetch),
|
Effect.andThen(runner.forkFetch),
|
||||||
), [runner, ...props.deps])
|
), [runner, ...props.key])
|
||||||
|
|
||||||
this.useFork(() => Stream.runForEach(
|
this.useFork(() => Stream.runForEach(
|
||||||
BrowserStream.fromEventListenerWindow("focus"),
|
BrowserStream.fromEventListenerWindow("focus"),
|
||||||
|
|||||||
@@ -13,12 +13,16 @@ export interface QueryRunner<A, E, R> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export interface MakeProps<A, E, R> {
|
||||||
|
readonly query: Effect.Effect<A, E, R>
|
||||||
|
}
|
||||||
|
|
||||||
export const make = <A, E, R>(
|
export const make = <A, E, R>(
|
||||||
query: Effect.Effect<A, E, R>
|
props: MakeProps<A, E, R>
|
||||||
): Effect.Effect<QueryRunner<A, E, R>, never, R> => Effect.gen(function*() {
|
): Effect.Effect<QueryRunner<A, E, R>, never, R> => Effect.gen(function*() {
|
||||||
const context = yield* Effect.context<R>()
|
const context = yield* Effect.context<R>()
|
||||||
|
|
||||||
const queryRef = yield* SubscriptionRef.make(query)
|
const queryRef = yield* SubscriptionRef.make(props.query)
|
||||||
const stateRef = yield* SubscriptionRef.make(AsyncData.noData<A, E>())
|
const stateRef = yield* SubscriptionRef.make(AsyncData.noData<A, E>())
|
||||||
const fiberRef = yield* SubscriptionRef.make(Option.none<Fiber.RuntimeFiber<void>>())
|
const fiberRef = yield* SubscriptionRef.make(Option.none<Fiber.RuntimeFiber<void>>())
|
||||||
|
|
||||||
|
|||||||
@@ -8,16 +8,22 @@ export interface QueryService<A, E> {
|
|||||||
readonly refresh: Effect.Effect<Fiber.RuntimeFiber<void>>
|
readonly refresh: Effect.Effect<Fiber.RuntimeFiber<void>>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export const Tag = <const Id extends string>(id: Id) => <
|
export const Tag = <const Id extends string>(id: Id) => <
|
||||||
Self, A, E = never,
|
Self, A, E = never,
|
||||||
>() => Effect.Tag(id)<Self, QueryService<A, E>>()
|
>() => Effect.Tag(id)<Self, QueryService<A, E>>()
|
||||||
|
|
||||||
|
|
||||||
|
export interface LayerProps<A, E, R> {
|
||||||
|
readonly query: Effect.Effect<A, E, R>
|
||||||
|
}
|
||||||
|
|
||||||
export const layer = <Self, Id extends string, A, E, R>(
|
export const layer = <Self, Id extends string, A, E, R>(
|
||||||
tag: Context.TagClass<Self, Id, QueryService<A, E>>,
|
tag: Context.TagClass<Self, Id, QueryService<A, E>>,
|
||||||
query: Effect.Effect<A, E, R>,
|
props: LayerProps<A, E, R>,
|
||||||
): Layer.Layer<Self, never, R> => Layer.effect(tag, Effect.gen(function*() {
|
): Layer.Layer<Self, never, R> => Layer.effect(tag, Effect.gen(function*() {
|
||||||
const runner = yield* QueryRunner.make(query)
|
const runner = yield* QueryRunner.make({
|
||||||
|
query: props.query
|
||||||
|
})
|
||||||
|
|
||||||
return {
|
return {
|
||||||
state: runner.stateRef,
|
state: runner.stateRef,
|
||||||
|
|||||||
Reference in New Issue
Block a user