import { Effect, Equivalence, Stream } from "effect" import { Subscribable } from "effect-lens" import * as React from "react" import * as Component from "./Component.js" export * from "effect-lens/Subscribable" export const zipLatestAll = []>( ...elements: T ): Subscribable.Subscribable< [T[number]] extends [never] ? never : { [K in keyof T]: T[K] extends Subscribable.Subscribable ? A : never }, [T[number]] extends [never] ? never : T[number] extends Subscribable.Subscribable ? E : never, [T[number]] extends [never] ? never : T[number] extends Subscribable.Subscribable ? R : never > => Subscribable.make({ get: Effect.all(elements.map(v => v.get)), changes: Stream.zipLatestAll(...elements.map(v => v.changes)), }) as any export declare namespace useAll { export type Success[]> = [T[number]] extends [never] ? never : { [K in keyof T]: T[K] extends Subscribable.Subscribable ? A : never } export interface Options { readonly equivalence?: Equivalence.Equivalence } } export const useAll = Effect.fnUntraced(function* []>( elements: T, options?: useAll.Options>>, ): Effect.fn.Return< useAll.Success, [T[number]] extends [never] ? never : T[number] extends Subscribable.Subscribable ? E : never, [T[number]] extends [never] ? never : T[number] extends Subscribable.Subscribable ? R : never > { const [reactStateValue, setReactStateValue] = React.useState( yield* Component.useOnMount(() => Effect.all(elements.map(v => v.get))) ) yield* Component.useReactEffect(() => Stream.zipLatestAll(...elements.map(ref => ref.changes)).pipe( Stream.changesWith((options?.equivalence as Equivalence.Equivalence | undefined) ?? Equivalence.Array(Equivalence.strictEqual())), Stream.runForEach(v => Effect.sync(() => setReactStateValue(v)) ), Effect.forkScoped, ), elements) return reactStateValue as any })