メインコンテンツへスキップ

Before you start

以下が必要です。
ACULでは、お好みのコンポーネントライブラリを使用してユニバーサルログインのプロンプト画面をカスタマイズできます。以下の例では、再利用可能なコンポーネントライブラリであるShadcnと、Auth0のlogin-passwordless-email-code画面を使用しています。この例ではデフォルトのOTP入力を、ShadcnのInputOTPコンポーネントに置き換えています。
  1. Auth0 CLIツールを使用してACULプロジェクトを作成します。
auth0 acul init <Your-App-Name>
login-passwordless-email-code画面を選択します
  1. ACULローカル開発サーバーを実行して、画面の更新を編集、表示します。
auth0 acul dev
  1. プロジェクトのルートでShadcnを初期化します。
npx shadcn-ui@latest init
  1. CLIプロンプトに従って、プロジェクトの構成を保持するためのcomponents.jsonファイルと、src/lib/utils.tsファイルを作成します。
  2. コンポーネントファイルをsrc/components/ui/input-otp.tsxに追加します。
npx shadcn-ui@latest add input-otp
  1. 次の手順でコンポーネントを組み込みます。 a. src/screens/login-passwordless-email-code/components/IdentifierForm.tsxに移動してファイルを開きます。 b. InputOTPコンポーネントをインポートし、既存の入力フィールドを置き換えます。また、OTPコードの状態を管理し、適切なSDKフックを使用する必要があります。
// In IdentifierForm.tsx
import { useState } from 'react';
import { useEmailOtpChallenge } from '@auth0/auth0-acul-react'; 
import {
  InputOTP,
  InputOTPGroup,
  InputOTPSlot,
} from '@/components/ui/input-otp'; // Import from ShadCN

// ... inside your component
const { submit } = useEmailOtpChallenge(); 
const [otp, setOtp] = useState('');

const handleSubmit = (e) => {
  e.preventDefault();
  submit({ code: otp }); // Call the submit method with the code
};

return (
  <form onSubmit={handleSubmit}>
    {/* ... other UI elements ... */}
    <InputOTP maxLength={6} value={otp} onChange={setOtp}>
      <InputOTPGroup>
        <InputOTPSlot index={0} />
        <InputOTPSlot index={1} />
        <InputOTPSlot index={2} />
        <InputOTPSlot index={3} />
        <InputOTPSlot index={4} />
        <InputOTPSlot index={5} />
      </InputOTPGroup>
    </InputOTP>
    <Button type="submit">Verify Code</Button>
  </form>
);
  1. 新しいコンポーネントを確認するには、ACULコンテキストインスペクターを使用してローカルで画面を実行します。
auth0 acul dev -s  login-passwordless-email-code
  1. ローカル開発環境をテスト用テナントに接続して、実際の認証フローで新しい画面を試します。
auth0 acul dev --connected --screen login-passwordless-email-code
  1. プロンプトに従ってローカルアセットを構築し、ローカル開発サーバーを起動して、テナント上のACUL構成を更新します。
  2. パスワードレス認証のフローをテストします。
auth0 test login