Skip to content

underground0930/react-hook-recaptcha-v2

Repository files navigation

react-hook-recaptcha-v2 npm version

Features

  • react-hook with built-in recaptcha-v2
  • Corresponding to checkbox and invisible.

Install

npm i react-hook-recaptcha-v2

Requirement

  • Node.js: v18.13.0

Depends on

  • react: 18.2.0

Usage

import { useRecaptchaV2 } from 'react-hook-recaptcha-v2'
const scriptId = 'rechapchaScriptId'
const sitekey = 'xxxxxxxxxxxx'

// checkbox type ////////////////////////////

export function Home {

// set token
const [token, setToken] = useState<string | null>(null)
const { recaptchaRef } = useRecaptchaV2({
  sitekey,
  scriptId,
  size: 'compact',
  hl: 'en',
  callback: (token) => setToken(token),
  expiredCallback: () => setToken(null),
  errorCallback: () => {
    alert('recapcha error')
    setToken(null)
  },
})

  const onSubmit = async (event: React.FormEvent<HTMLFormElement>) => {
    console.log(token);
    console.log(event.currentTarget.username.value)
    // fetch
  })

  return (
          <form onSubmit={onSubmit}>
            <input type='text' name='username' />
            <div ref={recaptchaRef}></div>
            <button>send</button>
          </form>
        )
}

// invisible type ////////////////////////////

export function Home {
const formRef = useRef<HTMLFormElement>(null)

const { recaptchaRef, executeRecaptcha } = useRecaptchaV2({
  sitekey,
  scriptId,
  size: 'invisible',
  hl: 'ja',
  callback: (token) => {
    if (token) {
      fetchData(token)
    }
  },
})

const onSubmit = async (event: React.FormEvent<HTMLFormElement>) => {
  event.preventDefault()
  await executeRecaptcha()
}

const fetchData = (token)=>{
  console.log(token);
  console.log(formRef.current?.username.value)
// fetch
}

  return (
          <form ref={formRef} onSubmit={onSubmit}>
            <input type='text' name='username' />
            <div ref={recaptchaRef}></div>
            <button>send</button>
          </form>
        )
}

Check the examples folder for details

props

key description default required
sitekey ⚫︎
scriptId ID to be attached to the script tag to be injected recaptchaApiScript
hl ja
size normal
badge bottomright
callback (token:string)=> void ⚫︎
expiredCallback ()=> void
errorCallback ()=> void

(※)Please click here for more information.

Return value of hook

value description type
recaptchaRef Reference to recapcha elements MutableRefObject
executeRecaptcha () => Promise
resetRecaptcha () => void

(※)Please click here for more information.

Get recaptcha sitekey and secretkey

https://www.google.com/recaptcha/admin

Author

License

"react-hook-recaptcha-v2" is under MIT license.

About

react-hook with built-in recaptcha-v2

Resources

Stars

Watchers

Forks

Packages

No packages published