Get started with Connect embedded components
Learn how to embed dashboard functionality into your website.
Use Connect embedded components to add connected account dashboard functionality to your website. These libraries and their supporting API allow you to grant your users access to Stripe products directly in your dashboard.
Private preview
The Android SDK is currently available with invite only and has the following limitations:
- Only accounts where
controller.
isrequirement_ collection application
, such as Custom connected accounts, are supported. - User authentication isn’t supported, so you must set features.disable_stripe_user_authentication to
true
in your server endpoint for any components when you create an account session.
Enter your email in the form below to request an invitation.
Set up StripeConnectClient-sideServer-side
Stripe uses an AccountSession to express your intent to delegate API access to your connected account.
The AccountSessions API returns a client secret that allows an embedded component in the web client to access a connected account’s resources as if you were making the API calls for them.
Create an AccountSession Server
Your app must initiate a request to your server to obtain the account session. You can create a new endpoint on your server that returns the client secret to the app:
Caution
User authentication isn’t supported, so you must set features.disable_stripe_user_authentication to true
in your server endpoint for any components when you create an account session.
Create Account Session API
The Create Account Session API determines component and feature access for Connect embedded components. Stripe enforces these parameters for any components that correspond to the account session. If your app supports multiple user roles, make sure components and features that are enabled for that account session correspond to the current user’s role. For example, you can enable refund management only for administrators of your site, but not for other users. To make sure user role access are enforced, you must map your site’s user role to account session components.
Install the StripeConnect SDK Client
The Stripe Android SDK is open source and fully documented.
To install the SDK, add connect
to the dependencies
block of your app/build.gradle file:
Note
For details on the latest SDK release and past versions, see the Releases page on GitHub. To receive notifications when a new release is published, watch releases for the repository.
Initialize EmbeddedComponentManager Client
Instantiate an EmbeddedComponentManager with your publishable key and a lambda that retrieves a client secret by calling the new endpoint you created on your server. In order to handle configuration changes, keep the EmbeddedComponentManager
instance in an Activity or Fragment ViewModel
.
To create a component, first call EmbeddedComponentManager.
in your Activity’s onCreate
method. Then, call the appropriate create method on the EmbeddedComponentManager
that you instantiated above. This returns a controller that you can use to present the component in the app.
Configure the Embedded Component ManagerClient-side
Customize the look of Connect embedded components
The embedded components Figma UI toolkit contains every component, common patterns, and an example application. You can use it to visualize and design embedded UIs on your website.
We offer a set of options to customize the look and feel of Connect embedded components. These customizations affect buttons, icons, and other accents in our design system.
Necessary popups
Some behavior in embedded components, such as user authentication, must be presented in a popup. You can’t customize the embedded component to eliminate such popups.
You can set these options using Appearance when initializing EmbeddedComponentManager
.
Use custom fonts 
If you use custom fonts in your app (for example, from .
or .
files embedded in your app binary), you must specify the font files in a CustomFontSource passed to the customFonts
argument when initializing EmbeddedComponentManager
. This gives Connect embedded components access to the font files to properly render the fonts.
Fonts specified in appearance
must use a CustomFontSource passed to the EmbeddedComponentManager
on initialization to properly render.
See the reference documentation .
Configure appearance 
When specifying font sizes, use the unscaled font size that displays for the device’s default size class. The embedded component automatically scales the font size based on the user’s Accessibility font settings.
See the full list of appearance options on Android.
Update Connect embedded components after initialization
Call the update
method to change the appearance of the embedded components after initialization:
Authentication
We offer a set of APIs to manage account sessions and user credentials in Connect embedded components.
Refresh the client secret
On long running sessions, the session from the initially provided client secret might expire. When it expires, we automatically use clientSecretProvider
to retrieve a new client secret and refresh the session. You don’t need to pass in any additional parameters.
Localization
Connect embedded components support the following locales:
Language | Locale code |
---|---|
Bulgarian (Bulgaria) | bg-BG |
Chinese (Simplified) | zh-Hans |
Chinese (Traditional - Hong Kong) | zh-Hant-HK |
Chinese (Traditional - Taiwan) | zh-Hant-TW |
Croatian (Croatia) | hr-HR |
Czech (Czechia) | cs-CZ |
Danish (Denmark) | da-DK |
Dutch (Netherlands) | nl-NL |
English (Australia) | en-AU |
English (India) | en-IN |
English (Ireland) | en-IE |
English (New Zealand) | en-NZ |
English (Singapore) | en-SG |
English (United Kingdom) | en-GB |
English (United States) | en-US |
Estonian (Estonia) | et-EE |
Filipino (Philippines) | fil-PH |
Finnish (Finland) | fi-FI |
French (Canada) | fr-CA |
French (France) | fr-FR |
German (Germany) | de-DE |
Greek (Greece) | el-GR |
Hungarian (Hungary) | hu-HU |
Indonesian (Indonesia) | id-ID |
Italian (Italy) | it-IT |
Japanese (Japan) | ja-JP |
Korean (South Korea) | ko-KR |
Latvian (Latvia) | lv-LV |
Lithuanian (Lithuania) | lt-LT |
Malay (Malaysia) | ms-MY |
Maltese (Malta) | mt-MT |
Norwegian Bokmål (Norway) | nb-NO |
Polish (Poland) | pl-PL |
Portuguese (Brazil) | pt-BR |
Portuguese (Portugal) | pt-PT |
Romanian (Romania) | ro-RO |
Slovak (Slovakia) | sk-SK |
Slovenian (Slovenia) | sl-SI |
Spanish (Argentina) | es-AR |
Spanish (Brazil) | es-BR |
Spanish (Latin America) | es-419 |
Spanish (Mexico) | es-MX |
Spanish (Spain) | es-ES |
Swedish (Sweden) | sv-SE |
Thai (Thailand) | th-TH |
Turkish (Türkiye) | tr-TR |
Vietnamese (Vietnam) | vi-VN |
Handle load errors 
If a component doesn’t load, you can react to the failure by implementing the component’s onLoadError
listener method. Depending on the cause of failure, the onLoadError
method might be called multiple times. Any logic triggered by a onLoadError
must be idempotent.
Request access Private preview
Sign in to request access to this Connect embedded component in preview.
If you don’t have a Stripe account, you can register now.