Installation

First, you need to set up a Corbado project.

To get started with the integration, install the Corbado web-js package:

npm install @corbado/web-js

If your project uses TypeScript, you should also install the types for the package:

npm install -D @corbado/types

Set up Corbado

Disable SSR for pages importing Corbado as it is not yet supported. We are working on SSR support and will update this guide once it is available.

routes/+layout.server.ts
export const ssr = false;

To inform the rest of our application of Corbado loading status, we will create a store.

src/corbadoStore.ts
import { writable } from 'svelte/store';

export const isCorbadoLoaded = writable(false);

Now, load Corbado in your root layout to make it available throughout your application.

routes/+layout.svelte
<script lang="ts">
    import Corbado from "@corbado/web-js";
    import {onMount} from "svelte";
    import {PUBLIC_CORBADO_PROJECT_ID} from '$env/static/public';
    import {isCorbadoLoaded} from "../corbadoStore";

    onMount(async () => {
        await Corbado.load({
            projectId: PUBLIC_CORBADO_PROJECT_ID,
            darkMode: 'off'
        });
        $isCorbadoLoaded = true;
    });
</script>

<div>
    <slot />
</div>

Configuration

Most configuration is done in the . The following options are available:

NameTypeDefaultDescription
projectIdstring (e.g. pro-1234567890)requiredThe ID of your Corbado project. This setting is mandatory and can be found in the Developer Panel.
autoDetectLanguagebooleantrueIf set to true the language used in UI components will be derived from the browser.
defaultLanguagestringenThe default language to be used if auto-detection is disabled or fails. Corbado supports “en”, “de” and “fr”. You can define custom translations though.
customTranslationsobjectnullA map from language (e.g. “en”) to an object containing your custom translation overrides. Find more details here
darkModeon | off | autoautoControls if your components are rendered in dark mode. If set to auto the darkMode setting will be derived from the browser.
themestringundefinedControls the style of your components. Currently, the only alternative theme that can be set here is emerald-funk. To create your own custom theme find all information here.
customerSupportEmailstringundefinedEmail address for customer support in case of critical errors.
isDevModebooleanfalseIf set to true, the UI components will log debug messages to console.
frontendApiUrlstringSet to your Frontend API URLPlease set this value when you go live to your defined CNAME.
apiTimeoutnumber30000Front-end api timeout time in miliseconds

Next

  1. Add authentication UI components to your application.
  2. Let your users manage their passkeys with the PasskeyList.
  3. Learn how you can access the users authentication state on the client-side.
  4. Easily access user information on the server-side with the Node.js SDK.