From 2550fdfecd88e81f9fc863aaabeca40716305d80 Mon Sep 17 00:00:00 2001 From: Luis Marsiglia Date: Mon, 21 Nov 2022 21:27:39 -0400 Subject: [PATCH] perf: improve typings --- src/lib.tsx | 4 +- src/types.d.ts | 100 ++++++++++++++++++++++++------------------------- tsconfig.json | 1 + 3 files changed, 51 insertions(+), 54 deletions(-) diff --git a/src/lib.tsx b/src/lib.tsx index 9e25942..e0e2e8d 100644 --- a/src/lib.tsx +++ b/src/lib.tsx @@ -1,6 +1,6 @@ import React, { forwardRef, useEffect, useImperativeHandle, useRef, useState } from 'react' import { DEFAULT_CONTAINER_ID, DEFAULT_ONLOAD_NAME, injectTurnstileScript } from './utils' -import { RenderParameters, TurnstileInstance, TurnstileProps } from './types' +import { RenderOptions, TurnstileInstance, TurnstileProps } from './types' export const Turnstile = forwardRef((props, ref) => { const { @@ -83,7 +83,7 @@ export const Turnstile = forwardRef string | undefined + render: (container?: string | HTMLElement, params?: RenderOptions) => string | undefined /** * Method to reset a widget. * @param id - Optional. ID of the widget to reset, if not provided will target the last rendered widget. @@ -58,8 +58,11 @@ interface TurnstileInstance { getResponse: () => string | undefined } -/** Common options for the `.render()` function and the `options` prop in the `` component */ -interface CommonRenderOptions { +interface RenderOptions { + /** + * The sitekey of your widget. This sitekey is created upon the widget creation. + */ + sitekey: string /** * A customer value that can be used to differentiate widgets under the same sitekey in analytics and which is returned upon validation. This can only contain up to 32 alphanumeric characters including _ and -. * @default undefined @@ -71,88 +74,82 @@ interface CommonRenderOptions { */ cData?: string /** - * The widget theme. This can be forced to light or dark by setting the theme accordingly. - * - * @default `auto` + * Callback that is invoked upon success of the challenge. The callback is passed a token that can be validated. + * @param token - Token response. */ - theme?: 'light' | 'dark' | 'auto' + callback?: (token: string) => void /** - * The widget size. Can take the following values: `normal`, `compact`. The normal size is 300x65px, the compact size is 130x120px. - * @default `normal` + * Callback that is invoked when a challenge expires. */ - size?: 'normal' | 'compact' + 'expired-callback'?: () => void /** - * Controls whether the widget should automatically retry to obtain a token if it did not succeed. The default is `'auto'`, which will retry automatically. This can be set to `'never'` to disable retry upon failure. + * Callback that is invoked when there is a network error. + */ + 'error-callback'?: () => void + /** + * The widget theme. This can be forced to light or dark by setting the theme accordingly. + * * @default `auto` */ - retry?: 'auto' | 'never' -} - -/** Props needed for the `options` prop in the `` component */ -interface ComponentRenderOptions extends CommonRenderOptions { + theme?: 'light' | 'dark' | 'auto' /** * The tabindex of Turnstile’s iframe for accessibility purposes. * @default 0 */ - tabIndex?: number + tabindex?: number /** * A boolean that controls if an input element with the response token is created. * @default true */ - responseField?: boolean + 'response-field'?: boolean /** * Name of the input element. * @default `cf-turnstile-response` */ - responseFieldName?: string + 'response-field-name'?: string /** - * When `retry` is set to `'auto'`, `retryInterval` controls the time between retry attempts in milliseconds. The value must be a positive integer less than `900000`. When `retry` is set to `'never'`, this parameter has no effect. + * The widget size. Can take the following values: `normal`, `compact`. The normal size is 300x65px, the compact size is 130x120px. + * @default `normal` + */ + size?: 'normal' | 'compact' + /** + * Controls whether the widget should automatically retry to obtain a token if it did not succeed. The default is `'auto'`, which will retry automatically. This can be set to `'never'` to disable retry upon failure. + * @default `auto` + */ + retry?: 'auto' | 'never' + /** + * When `retry` is set to `'auto'`, `retry-interval` controls the time between retry attempts in milliseconds. The value must be a positive integer less than `900000`. When `retry` is set to `'never'`, this parameter has no effect. * @default 8000 */ - retryInterval?: number + 'retry-interval'?: number } -/** Props needed for the `.render()` function */ -interface RenderParameters extends CommonRenderOptions { - /** - * Every widget has a sitekey. This sitekey is associated with the corresponding widget configuration and is created upon the widget creation. - */ - sitekey: string +/** Props needed for the `options` prop in the `` component. */ +interface ComponentRenderOptions + extends Pick { /** * The tabindex of Turnstile’s iframe for accessibility purposes. * @default 0 */ - tabindex?: number - /** - * JavaScript callback that is invoked upon success of the challenge. The callback is passed a token that can be validated. - * @param token - Token response. - */ - callback?: (token: string) => void - /** - * JavaScript callback that is invoked when a challenge expires. - */ - 'expired-callback'?: () => void - /** - * JavaScript callback that is invoked when there is a network error. - */ - 'error-callback'?: () => void + tabIndex?: RenderOptions['tabindex'] /** * A boolean that controls if an input element with the response token is created. * @default true */ - 'response-field'?: boolean + responseField?: RenderOptions['response-field'] /** * Name of the input element. * @default `cf-turnstile-response` */ - 'response-field-name'?: string + responseFieldName?: RenderOptions['response-field-name'] /** - * When `retry` is set to `'auto'`, `retry-interval` controls the time between retry attempts in milliseconds. The value must be a positive integer less than `900000`. When `retry` is set to `'never'`, this parameter has no effect. + * When `retry` is set to `'auto'`, `retryInterval` controls the time between retry attempts in milliseconds. The value must be a positive integer less than `900000`. When `retry` is set to `'never'`, this parameter has no effect. * @default 8000 */ - 'retry-interval'?: number + retryInterval?: RenderOptions['retry-interval'] } +/** Custom options for the injected script. */ interface ScriptOptions { /** * Custom nonce for the injected script. @@ -188,24 +185,23 @@ interface ScriptOptions { /** `` component props */ interface TurnstileProps extends React.HTMLAttributes { - // instance: React.RefObject /** - * Every widget has a sitekey. This sitekey is associated with the corresponding widget configuration and is created upon the widget creation. + * The sitekey of your widget. This sitekey is created upon the widget creation. */ - siteKey: string + siteKey: RenderOptions['sitekey'] /** * Callback that is invoked upon success of the challenge. The callback is passed a token that can be validated. * @param token - Token response. */ - onSuccess?: (token: string) => void + onSuccess?: RenderOptions['callback'] /** * Callback that is invoked when a challenge expires. */ - onExpire?: () => void + onExpire?: RenderOptions['expired-callback'] /** * Callback that is invoked when there is a network error. */ - onError?: () => void + onError?: RenderOptions['error-callback'] /** * Custom widget render options. See {@link https://developers.cloudflare.com/turnstile/get-started/client-side-rendering/#configurations the docs} for more info about this options. */ @@ -229,4 +225,4 @@ interface InjectTurnstileScriptParams { scriptOptions?: Omit } -export type { TurnstileInstance, RenderParameters, TurnstileProps, InjectTurnstileScriptParams } +export type { TurnstileInstance, RenderOptions, TurnstileProps, InjectTurnstileScriptParams } diff --git a/tsconfig.json b/tsconfig.json index e6a7e2d..84fcb92 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -15,6 +15,7 @@ "isolatedModules": true, "rootDir": ".", "baseUrl": ".", + "noEmit": true, "paths": { "~/*": ["./*"] }