0.1.3 #4

Merged
Thilawyn merged 90 commits from next into master 2025-08-23 03:07:28 +02:00
Showing only changes of commit 6f9e0729fc - Show all commits

View File

@@ -30,14 +30,19 @@ export const useInput: {
const [error, setError] = React.useState(Option.none<ParseResult.ParseError>()) const [error, setError] = React.useState(Option.none<ParseResult.ParseError>())
yield* useFork(() => Effect.all([ yield* useFork(() => Effect.all([
// Sync the upstream state with the internal state
// Only mutate the internal state if the upstream encoded value is actually different. This avoids infinite re-render loops.
Stream.runForEach(options.ref.changes, upstreamValue => Stream.runForEach(options.ref.changes, upstreamValue =>
Effect.andThen(internalRef, internalValue => Effect.andThen(
upstreamValue !== internalValue Effect.all([Schema.encode(options.schema)(upstreamValue), internalRef]),
? Effect.andThen(Schema.encode(options.schema)(upstreamValue), v => Ref.set(internalRef, v)) ([encodedUpstreamValue, internalValue]) => Effect.when(
: Effect.void Ref.set(internalRef, encodedUpstreamValue),
() => encodedUpstreamValue !== internalValue,
),
) )
), ),
// Sync all changes to the internal state with upstream
Stream.runForEach( Stream.runForEach(
internalRef.changes.pipe(options.debounce ? Stream.debounce(options.debounce) : identity), internalRef.changes.pipe(options.debounce ? Stream.debounce(options.debounce) : identity),
flow( flow(