next.js/test/e2e/app-dir/use-cache-with-server-function-props/app/server-action/form.tsx
form.tsx26 lines651 B
'use client'

import { useActionState } from 'react'

export function Form({
  sayHi,
  sayHello,
}: {
  sayHi: () => Promise<string>
  sayHello: () => Promise<string>
}) {
  const [hi, hiAction, isHiPending] = useActionState(sayHi, null)
  const [hello, helloAction, isHelloPending] = useActionState(sayHello, null)

  return (
    <form action={hiAction}>
      <button id="submit-button-hi">Say Hi</button>{' '}
      <button id="submit-button-hello" formAction={helloAction}>
        Say Hello
      </button>
      <p id="hi">{isHiPending ? 'loading...' : hi}</p>
      <p id="hello">{isHelloPending ? 'loading...' : hello}</p>
    </form>
  )
}
Quest for Codev2.0.0
/
SIGN IN