Åtgärder och onboarding efter installation
Åtgärder efter installation avgör vad som händer omedelbart efter att en användare installerar din Stripe-app. En väldesignad upplevelse efter installation vägleder användarna genom installationen och ökar aktiveringsgraden.
Typer av åtgärder efter installation
Stripe stöder fyra typer av åtgärder efter installation, var och en konfigurerad i ditt appmanifest:
1. Länk till app (standard)
Öppnar appen i standard drawer-viewporten. Detta är standardbeteendet om ingen post_install_action anges:
{ "post_install_action": { "type": "default" }}Användaren ser appens drawer.default-viewport i Stripe Dashboard-sidofältet.
2. Länk till onboarding
Öppnar appens dedikerade onboardingvy och ger en fokuserad konfigurationsupplevelse:
{ "post_install_action": { "type": "onboarding" }}Detta kräver en onboarding-viewport deklarerad i ditt manifest:
{ "ui_extension": { "views": [ { "viewport": "stripe.dashboard.onboarding", "component": "OnboardingView" } ] }, "post_install_action": { "type": "onboarding" }}3. Länk till inställningar
Öppnar appens inställningsvy, användbart när appen kräver API-nycklar eller konfiguration innan användning:
{ "post_install_action": { "type": "settings" }}Detta kräver en settings-viewport:
{ "ui_extension": { "views": [ { "viewport": "stripe.dashboard.settings", "component": "SettingsView" } ] }, "post_install_action": { "type": "settings" }}4. Länk till extern URL
Omdirigerar användaren till en extern URL för konfiguration. Använd detta när ditt onboardingflöde finns utanför Stripe Dashboard:
{ "post_install_action": { "type": "external", "url": "https://app.tajo.io/stripe/setup" }}Caution
Externa URL:er måste använda HTTPS och bör listas i dina allowed_redirect_uris. Stripe-granskningsteamet kommer att verifiera att den externa URL:en ger en funktionell konfigurationsupplevelse.
Bästa praxis för onboarding
Gör det enkelt
Minimera antalet steg som krävs för att komma igång:
- Fyll i information i förväg tillgänglig från Stripe-kontokontexten
- Använd rimliga standardvärden för konfigurationsalternativ
- Tillåt att hoppa över valfria steg med en tydlig väg att slutföra dem senare
- Visa framsteg med stegindikator för flerstegflöden
Gör det anpassningsbart
Låt användarna konfigurera integrationen efter sina behov:
- Datamappningsalternativ, låt användarna välja vilka Stripe-fält som synkroniseras till Brevo
- Synkroniseringsfrekvens, erbjud alternativ för realtid, varje timme eller daglig synkronisering
- Selektiv synkronisering, låt användarna välja vilka kunder eller produkter som ska synkroniseras
- Notifikationsinställningar, konfigurera aviseringar för synkroniseringsfel eller viktiga händelser
Gör det relevant
Visa värde omedelbart:
- Förhandsgranska synkroniserad data innan integrationen aktiveras
- Visa vad som kommer att hända när användaren slutför konfigurationen
- Tillhandahåll ett testsynkroniseringsalternativ för att verifiera att anslutningen fungerar
- Visa framgångsmätvärden efter att den initiala synkroniseringen är klar
OnboardingView-komponenten
Komponenten OnboardingView renderas i en fokuserad modal när användaren installerar appen:
import { Box, Button, Inline, Icon, Banner, TextField, Select, Divider,} from '@stripe/ui-extension-sdk/ui';import type { ExtensionContextValue } from '@stripe/ui-extension-sdk/context';import { useState } from 'react';
const OnboardingView = ({ environment, userContext }: ExtensionContextValue) => { const [step, setStep] = useState(1); const [brevoApiKey, setBrevoApiKey] = useState(''); const [syncMode, setSyncMode] = useState('realtime'); const [isConnecting, setIsConnecting] = useState(false); const [error, setError] = useState<string | null>(null);
const totalSteps = 3;
const handleConnect = async () => { setIsConnecting(true); setError(null);
try { // Store the API key securely await storeBrevoApiKey(brevoApiKey);
// Verify the connection const result = await verifyBrevoConnection(brevoApiKey);
if (result.success) { setStep(2); } else { setError('Unable to connect to Brevo. Please check your API key.'); } } catch (err) { setError('Connection failed. Please try again.'); } finally { setIsConnecting(false); } };
return ( <Box css={{ padding: 'large' }}> {/* Progress indicator */} <Inline css={{ marginBottom: 'large' }}> Step {step} of {totalSteps} </Inline>
{error && ( <Banner type="critical" title="Connection Error"> {error} </Banner> )}
{step === 1 && ( <Box> <Inline css={{ fontWeight: 'bold', fontSize: 'large' }}> Connect Your Brevo Account </Inline> <Inline css={{ marginTop: 'small', color: 'secondary' }}> Enter your Brevo API key to start syncing customer data. </Inline>
<TextField label="Brevo API Key" placeholder="xkeysib-..." value={brevoApiKey} onChange={(e) => setBrevoApiKey(e.target.value)} css={{ marginTop: 'medium' }} />
<Inline css={{ marginTop: 'xsmall', color: 'secondary', fontSize: 'small' }}> Find your API key in Brevo under Settings > SMTP & API > API Keys </Inline>
<Button type="primary" onPress={handleConnect} disabled={!brevoApiKey || isConnecting} css={{ marginTop: 'medium' }} > {isConnecting ? 'Connecting...' : 'Connect Brevo'} </Button> </Box> )}
{step === 2 && ( <Box> <Inline css={{ fontWeight: 'bold', fontSize: 'large' }}> Configure Sync Settings </Inline>
<Select label="Sync Mode" value={syncMode} onChange={(value) => setSyncMode(value)} css={{ marginTop: 'medium' }} > <option value="realtime">Real-time (recommended)</option> <option value="hourly">Every hour</option> <option value="daily">Once per day</option> </Select>
<Divider css={{ marginY: 'medium' }} />
<Button type="primary" onPress={() => setStep(3)}> Continue </Button> <Button type="secondary" onPress={() => setStep(1)}> Back </Button> </Box> )}
{step === 3 && ( <Box> <Banner type="default" title="Ready to Sync"> Your Brevo account is connected. Tajo will begin syncing customer data automatically. </Banner>
<Box css={{ marginTop: 'medium' }}> <Inline css={{ fontWeight: 'bold' }}>What happens next:</Inline> <ul> <li>Existing Stripe customers will sync to Brevo contacts</li> <li>New customers and events will sync in real-time</li> <li>View sync status on any customer's detail page</li> </ul> </Box>
<Button type="primary" onPress={() => {/* Navigate to dashboard */}}> Go to Dashboard </Button> </Box> )} </Box> );};
export default OnboardingView;Inloggningsflöde med SignInView
Om din app kräver att användare loggar in på ett externt konto (som Tajo), använd en dedikerad inloggningsvy:
import { Box, Button, Inline, TextField, Banner, Link,} from '@stripe/ui-extension-sdk/ui';import { useState } from 'react';
const SignInView = ({ onSignInComplete }) => { const [email, setEmail] = useState(''); const [password, setPassword] = useState(''); const [isLoading, setIsLoading] = useState(false); const [error, setError] = useState<string | null>(null);
const handleSignIn = async () => { setIsLoading(true); setError(null);
try { const response = await fetch('https://api.tajo.io/v1/auth/stripe-app', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ email, password }), });
if (!response.ok) { throw new Error('Invalid credentials'); }
const { token } = await response.json();
// Store the auth token securely in Stripe's Secret Store await storeAuthToken(token);
onSignInComplete(); } catch (err) { setError('Sign-in failed. Please check your credentials and try again.'); } finally { setIsLoading(false); } };
return ( <Box css={{ padding: 'large' }}> <Inline css={{ fontWeight: 'bold', fontSize: 'large' }}> Sign in to Tajo </Inline> <Inline css={{ marginTop: 'small', color: 'secondary' }}> Connect your Tajo account to enable Brevo sync. </Inline>
{error && ( <Banner type="critical" title="Sign-in Failed"> {error} </Banner> )}
<TextField label="Email" type="email" value={email} onChange={(e) => setEmail(e.target.value)} css={{ marginTop: 'medium' }} />
<TextField label="Password" type="password" value={password} onChange={(e) => setPassword(e.target.value)} css={{ marginTop: 'small' }} />
<Button type="primary" onPress={handleSignIn} disabled={!email || !password || isLoading} css={{ marginTop: 'medium' }} > {isLoading ? 'Signing in...' : 'Sign In'} </Button>
<Link href="https://app.tajo.io/signup" external css={{ marginTop: 'small' }}> Don't have a Tajo account? Sign up </Link> </Box> );};Djuplänksstart med frågeparametrar
Du kan starta specifika onboardingsteg eller förifyllda data med frågeparametrar i djuplänkar:
import type { ExtensionContextValue } from '@stripe/ui-extension-sdk/context';
const OnboardingView = ({ environment }: ExtensionContextValue) => { // Access query parameters from the deep link const { queryParams } = environment;
// Pre-fill step from query parameter const initialStep = queryParams?.step ? parseInt(queryParams.step) : 1;
// Pre-fill API key from query parameter (e.g., from Tajo dashboard) const prefilledApiKey = queryParams?.brevo_key || '';
// Source tracking for analytics const installSource = queryParams?.source || 'marketplace';
const [step, setStep] = useState(initialStep); const [brevoApiKey, setBrevoApiKey] = useState(prefilledApiKey);
// ... rest of onboarding logic};Generera djuplänkar som förifylls med onboardingdata:
// From your Tajo dashboard, generate a link that pre-fills the Brevo API keyconst onboardingLink = [ 'https://dashboard.stripe.com/live/acct_xxxxx/dashboard', '?apps[com.tajo.brevo-integration][modal]=stripe.dashboard.onboarding', '&apps[com.tajo.brevo-integration][queryParams][step]=1', '&apps[com.tajo.brevo-integration][queryParams][source]=tajo_dashboard',].join('');Hantera återvändande användare
När en användare öppnar din app efter att ha slutfört onboarding, identifiera deras tillstånd och visa lämplig vy:
const MainView = ({ environment, userContext }: ExtensionContextValue) => { const [authState, setAuthState] = useState<'loading' | 'signed-out' | 'onboarding' | 'ready'>('loading');
useEffect(() => { checkUserState().then((state) => { setAuthState(state); }); }, []);
switch (authState) { case 'loading': return <Spinner label="Loading..." />; case 'signed-out': return <SignInView onSignInComplete={() => setAuthState('onboarding')} />; case 'onboarding': return <OnboardingView onComplete={() => setAuthState('ready')} />; case 'ready': return <DashboardView />; }};Tip
Lagra status för slutförd onboarding i Stripe Secret Store så att du kan identifiera återvändande användare utan ett externt API-anrop.