Common components
Clerk Elements provides a set of common components that are used across all flows. It's recommended to import them all under the Clerk
namespace to make discovery easier and reduce naming conflicts with other common components throughout your application. The code snippets on this page assume you have imported the components this way.
Unless otherwise mentioned, all components accept a className
prop.
<Connection>
Renders a social connection button based on the provided name
. Throws an error in development if the provided social connection is not enabled in your instance. See Social connections (OAuth) to learn how to enable them in the Clerk Dashboard.
By default, <Connection>
will be rendered as an unstyled <button>
.
Properties
- Name
asChild
- Type
boolean
(optional)- Description
If
true
,<Connection>
will render as its child element, passing along any necessary props. Default:false
- Name
name
- Type
string
- Description
Name of the social connection to render.
You can enrich this example by providing an <Icon>
to display the social connection's logo.
<Field>
Associates its child elements with a specific <Input>
. It automatically generates unique IDs and associates child <Label>
and <Input>
elements with each other.
Properties
- Name
name
- Type
'code' | 'confirmPassword' | 'currentPassword' | 'emailAddress' | 'firstName' | 'identifier' | 'lastName' | 'name' | 'newPassword' | 'password' | 'phoneNumber' | 'username'
- Description
Name for form field, will be used to associate all underlying field elements.
- Name
alwaysShow?
- Type
boolean
- Description
When
true
, the field will always be rendered, regardless of its state. Whenfalse
, the field is hidden if it's optional or if it's a filled-out required field. Default:false
- Name
children?
- Type
(state: 'success' | 'error' | 'warning' | 'info' | 'idle') => React.ReactNode
- Description
Provide a function as children and access the field's state.
Usage
Place common components like <Input>
, <FieldError>
, or <Label>
inside <Field>
.
Function as children
The state
you can access here is the same as in <FieldState>
.
<FieldError>
Renders error messages associated with a specific <Field>
. By default, the error's message will be rendered in an unstyled <span>
. Optionally, the children
prop accepts a function to customize rendering.
Properties
- Name
name?
- Type
string
- Description
Used to target a specific field by name when rendering outside of a
<Field>
component. Default: Automatically inferred
- Name
asChild?
- Type
boolean
- Description
If
true
,<FieldError>
will render as its child element, passing along any necessary props. Default:false
- Name
children?
- Type
({ message: string, code: string }) => React.ReactNode
- Description
Provide a function as children and access the error's
message
andcode
.
Usage
If the <Field>
is in an error state, <FieldError>
will display its message.
Function as children
By having access to both message
and code
you can enrich the incoming message
or localize it by checking for a specific code
.
<FieldState>
Enables you to programmatically access additional information from the parent <Field>
component. By default, you'll have access to state
. state
will also contain the field's ValidityState
. <FieldState>
is useful for implementing animations if you need direct access to the state
value.
If you use <Input type="password" validatePassword>
, additional information in the form of message
and codes
is provided.
Properties
- Name
children
- Type
(args: { state: 'success' | 'error' | 'warning' | 'info' | 'idle'; message: string | undefined; codes: (string | [string, Record<string, string | number>])[] | undefined }) => React.ReactNode
- Description
Use this function to access the field's state. Optionally, information regarding password validation is given.
Usage
<Input>
will start with a state
of idle
until the user interacts with it. Depending on the user's input, the state
will change to success
or error
.
<Input type="password" validatePassword>
If you're using <Input type="password" validatePassword>
, the <FieldState>
's children function receives additional arguments:
- Name
message
- Type
string
- Description
The standardized English message generated for the current state of the input. This message is generated based on the codes associated with the
<FieldState>
.
- Name
codes
- Type
(string | [string, Record<string, string | number>])[]
- Description
The error codes associated with the
<FieldState>
. You can use these codes to return a custommessage
or localize its contents.
Initially, the <Input>
will have a state
of idle
until the user interacts with the input. Depending on the user's input, the state
will change to 'success' | 'error' | 'warning' | 'info'
.
<GlobalError />
Renders errors that are returned from Clerk's API but are not associated with a specific form field. By default, renders the error's message wrapped in a <div>
. Optionally, the children
prop accepts a function to customize rendering. Must be a child of components like <SignIn>
/<SignUp>
to have access to the underlying form state.
Properties
- Name
asChild?
- Type
boolean
- Description
If
true
,<GlobalError>
will render as its child element, passing along any necessary props. Default:false
- Name
code?
- Type
string
- Description
Forces the message with the matching code to be shown. This is useful when using server-side validation. Default:
undefined
- Name
children?
- Type
({ message: string, code: string }) => React.ReactNode
- Description
Provide a function as children and access the error's
message
andcode
.
Function as children
By having access to both message
and code
you can enrich the incoming message
or localize it by checking for specific code
.
<Icon>
By default, renders as an <img>
element with the logo of the parent <Connection>
as the value of its src
prop. Must be a child of <Connection>
.
- Name
asChild?
- Type
boolean
- Description
If
true
,<Icon>
will render as its child element, passing along any necessary props. Default:false
Usage
The following example demonstrates how to render the Google social connection logo with <Icon>
:
<Input>
Handles rendering of <input />
elements within Clerk's flows. Supports special type
prop values to render input types that are unique to authentication and user management flows. Additional props will be passed through to the <input />
.
- Name
asChild?
- Type
boolean
- Description
If
true
,<Input>
will render as its child element, passing along any necessary props. Default:false
- Name
name?
- Type
string
- Description
Name for the form field. Will be used to associate all underlying field elements. Can be automatically inferred from the name on the
<Field>
component.
- Name
type?
- Type
'text' | 'email' | 'tel' | 'otp'* | 'password'
- Description
Type for the input. Default:
'text'
- Name
autoComplete?
- Type
string
- Description
Refers to the HTML attribute. If
<Input>
is used inside a<SignIn>
flow andautoComplete="webauthn"
is set, passkey autofill will be attempted.
The following data attributes are also added to the underlying element:
data-valid
- If the field state is validdata-invalid
- If the field state is invalid (Either theValidityState
or has an associated error from Clerk's API)date-state
- Refers to the<FieldState>
statusdata-has-value
- If the input has a value
Usage
<Input type="otp">
A special type used to render an input that accepts a one-time passcode (OTP). If the corresponding <Field>
has name="code"
, the child <Input>
will default to the otp
type. Only numbers are accepted as inputs, and the default max length is 6.
By default, a single text <input />
will be rendered. If provided, the render
prop will be called for each character present in the input. This enables UI patterns where an OTP input is visually represented as N distinct elements.
Properties
- Name
length?
- Type
number
- Description
Sets how many digits the input number can be. Default:
6
- Name
autoSubmit?
- Type
boolean
- Description
If
true
, the form will be automatically submitted once the input is filled out. Default:false
- Name
passwordManagerOffset?
- Type
number
- Description
Password managers place their icon inside an
<input />
. This default behaviour is not desirable when you use the render prop to display N distinct element. With this prop you can increase the width of the<input />
so that the icon is rendered outside the OTP inputs. Default:40
- Name
render?
- Type
({ value, status }: { value: string; status: 'none' | 'selected' | 'cursor' | 'hovered' }) => React.ReactNode
- Description
A render prop function that receives the
value
andstatus
of each character.value
is the character to render,status
is the current status of the input character.
The properties asChild
and name
from <Input>
also apply to <Input type="otp">
.
The following data attributes are also added to the underlying element:
data-otp-input
Usage
A single <input type="text" />
input that only allows 6 numbers to be entered. Once the user filled in all information, the form is automatically submitted.
Segmented
You can render each number into an individual item and animate its appearance depending on the status
.
<Input type="password">
A thin wrapper around the <input type="password" />
element to provide password validation logic. You can define password rules in the Clerk Dashboard. By default, this validation is turned off and you need to set a validatePassword
prop.
Once activated, you can access the instant validation feedback through <FieldState>
and display rich information to your users.
Properties
- Name
validatePassword?
- Type
boolean
- Description
If
true
, password validation according to your password rules is happening while the user types in their password. Default:false
The following data attributes are also added to the underlying Element if validatePassword
is true
:
data-has-passed-validation
- If the password has passed the validation or not
The existing data attributes from <Input>
are also present on this Element.
Usage
For more information on how to use state
, codes
, and message
check the <FieldState>
docs.
<Label>
Renders a <label>
element that is automatically associated with its sibling <Input />
inside of a <Field>
. Additional props will be passed through to the <label>
element.
Properties
- Name
asChild?
- Type
boolean
- Description
If
true
,<Label />
will render as its child element, passing along any necessary props. Default:false
<Loading>
Enables you to access the loading state of a chosen scope. Scope can refer to a step, a <Connection>
, or the global loading state. The global loading state is true
when any of the other scopes are loading.
Properties
- Name
children
- Type
(isLoading: boolean) => React.ReactNode
- Description
A function that receives
isLoading
as an argument.isLoading
is a boolean that indicates if the current scope is loading or not.
- Name
scope?
- Type
string
- Description
Specify which loading state to access. Can be a step, a connection, or the global loading state. If
<Loading>
is used outside a<Step>
, the scope will default to'global'
. If used inside a<Step>
the scope will default to the current step. For external authentication providers, the scope needs to be manually defined in the format ofprovider:<provider name>
. Default:'global'
Relying on the auto-inference of the scope can be helpful when using <Loading>
in shared components, which might be referenced inside different steps. You won't need to manually pass the scope as a prop to your shared component.
Usage
Nested loading states
To target the loading state of a specific <Connection>
, you need to specify the scope as provider:<provider name>
.
Feedback
Last updated on