import { TextFieldFormInput } from "@/lib/form/TextFieldFormInput" import { runtime } from "@/runtime" import { Button, Container, Flex } from "@radix-ui/themes" import { createFileRoute } from "@tanstack/react-router" import { Effect, Schema } from "effect" import { Component, Form } from "effect-fc" import { useContext, useSubscribables } from "effect-fc/hooks" const email = Schema.pattern( /^(?!\.)(?!.*\.\.)([A-Z0-9_+-.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9-]*\.)+[A-Z]{2,}$/i, { identifier: "email", title: "email", message: () => "Not an email address", }, ) const RegisterFormSchema = Schema.Struct({ email: Schema.String.pipe(email), password: Schema.String.pipe(Schema.minLength(3)), }) class RegisterForm extends Effect.Service()("RegisterForm", { scoped: Form.service({ schema: RegisterFormSchema, initialEncodedValue: { email: "", password: "" }, submit: () => Effect.andThen( Effect.sleep("500 millis"), Effect.sync(() => alert("Done!")), ), }) }) {} class RegisterPage extends Component.makeUntraced("RegisterPage")(function*() { const form = yield* RegisterForm const submit = yield* Form.useSubmit(form) const [canSubmit] = yield* useSubscribables(form.canSubmitSubscribable) const TextFieldFormInputFC = yield* TextFieldFormInput return (
{ e.preventDefault() void submit() }}>
) }) {} const RegisterRoute = Component.makeUntraced(function* RegisterRoute() { const context = yield* useContext(RegisterForm.Default, { finalizerExecutionMode: "fork" }) const RegisterRouteFC = yield* Effect.provide(RegisterPage, context) return }).pipe( Component.withRuntime(runtime.context) ) export const Route = createFileRoute("/form")({ component: RegisterRoute })