next.js/test/e2e/app-dir/actions/app/header/ui.js
ui.js100 lines2.3 KB
'use client'

import { useState } from 'react'

export default function UI({
  getCookie,
  getHeader,
  setCookie,
  setCookieAndRedirect,
  getAuthedUppercase,
}) {
  const [result, setResult] = useState('')

  return (
    <div>
      <h1>{result}</h1>
      <button
        id="cookie"
        onClick={async () => {
          // set cookie
          const random = Math.random()
          document.cookie = `random=${random}`
          const res = await getCookie('random')
          setResult(random + ':' + res.value)
        }}
      >
        getCookie
      </button>
      <button
        id="setCookie"
        onClick={async () => {
          // set cookie on server side
          const random = Math.random()
          const res = await setCookie('random-server', random)
          setResult(
            random +
              ':' +
              res.value +
              ':' +
              document.cookie.match(/random-server=([^;]+)/)?.[1]
          )
        }}
      >
        setCookie
      </button>
      <button
        id="header"
        onClick={async () => {
          const res = await getHeader('User-Agent')
          setResult(res)
        }}
      >
        getHeader
      </button>
      <button
        id="authed"
        onClick={async () => {
          try {
            const res = await getAuthedUppercase('hello, world')
            setResult(res)
          } catch (err) {
            setResult('Error: ' + err.message)
          }
        }}
      >
        getAuthedUppercase
      </button>
      <form>
        <button
          id="setCookieAndRedirect"
          formAction={async () => {
            await setCookieAndRedirect(
              'redirect',
              Math.random().toString(36).substring(7),
              '/redirect-target'
            )
          }}
        >
          setCookieAndRedirect
        </button>
      </form>
      <form>
        <button
          id="setCookieAndRedirectReplace"
          formAction={async () => {
            await setCookieAndRedirect(
              'redirect',
              Math.random().toString(36).substring(7),
              '/redirect-target',
              'replace'
            )
          }}
        >
          setCookieAndRedirectReplace
        </button>
      </form>
    </div>
  )
}
Quest for Codev2.0.0
/
SIGN IN