0.1.6 (#9)
All checks were successful
Publish / publish (push) Successful in 29s
Lint / lint (push) Successful in 13s

Co-authored-by: Julien Valverdé <julien.valverde@mailo.com>
Reviewed-on: https://gitea:3000/Thilawyn/reffuse/pulls/9
This commit was merged in pull request #9.
This commit is contained in:
Julien Valverdé
2025-04-12 23:58:25 +02:00
parent d7c648994d
commit 4092da0f0c
15 changed files with 320 additions and 268 deletions

View File

@@ -37,7 +37,7 @@ function RouteComponent() {
)
})
const [state] = R.useRefState(mutation.state)
const [state] = R.useSubscribeRefs(mutation.state)
return (

View File

@@ -31,7 +31,7 @@ function RouteComponent() {
),
})
const [state] = R.useRefState(query.state)
const [state] = R.useSubscribeRefs(query.state)
return (

View File

@@ -1,9 +1,8 @@
import { R } from "@/reffuse"
import { Button, Flex } from "@radix-ui/themes"
import { Button, Flex, Text } from "@radix-ui/themes"
import { createFileRoute } from "@tanstack/react-router"
import { GetRandomValues, makeUuid4 } from "@typed/id"
import { Console, Effect, Stream } from "effect"
import { useState } from "react"
import { Console, Effect, Ref } from "effect"
export const Route = createFileRoute("/tests")({
@@ -22,9 +21,9 @@ function RouteComponent() {
Effect.delay("1 second"),
), [])
const [reactValue, setReactValue] = useState("initial")
const reactValueStream = R.useStreamFromValues([reactValue])
R.useFork(() => Stream.runForEach(reactValueStream, Console.log), [reactValueStream])
const uuidRef = R.useRef("none")
const anotherRef = R.useRef(69)
const logValue = R.useCallbackSync(Effect.fn(function*(value: string) {
@@ -33,12 +32,16 @@ function RouteComponent() {
const generateUuid = R.useCallbackSync(() => makeUuid4.pipe(
Effect.provide(GetRandomValues.CryptoRandom),
Effect.map(setReactValue),
Effect.flatMap(v => Ref.set(uuidRef, v)),
), [])
return (
<Flex direction="row" justify="center" align="center" gap="2">
<R.SubscribeRefs refs={[uuidRef, anotherRef]}>
{(uuid, anotherRef) => <Text>{uuid} / {anotherRef}</Text>}
</R.SubscribeRefs>
<Button onClick={() => logValue("test")}>Log value</Button>
<Button onClick={() => generateUuid()}>Generate UUID</Button>
</Flex>