Warenkorbabbruch-Recovery

Warenkorbabbruch-Recovery

Holen Sie verlorene Verkäufe mit einer intelligenten, mehrstufigen E-Mail-Sequenz zurück. Dieser Skill überwacht Warenkorbabbrüche und sendet automatisch personalisierte Recovery-E-Mails, um Kund:innen zurückzuholen.

Überblick

EigenschaftWert
KategorieE-Mail-Marketing
StatusStable
Version3.0
Triggercart_abandoned, cart_recovered
Durchschnittliche Recovery-Rate10–15 %

Funktionsweise

graph TD
A[Customer adds to cart] -->|Leaves site| B{Cart abandoned?}
B -->|No checkout in 30min| C[Trigger: cart_abandoned]
C --> D[Wait 1 hour]
D --> E{Purchased?}
E -->|No| F[Send Email #1]
F --> G[Wait 24 hours]
G --> H{Purchased?}
H -->|No| I[Send Email #2 + Discount]
I --> J[Wait 48 hours]
J --> K{Purchased?}
K -->|No| L[Send Email #3 - Final]
E -->|Yes| M[Stop sequence]
H -->|Yes| M
K -->|Yes| M
L --> N[Mark as lost]

Konfiguration

Grundeinrichtung

skills:
abandoned-cart:
enabled: true
# Cart abandonment detection
detection:
inactivity_threshold: 30m # Minutes before cart is abandoned
min_cart_value: 25 # Minimum cart value to trigger
exclude_logged_out: false # Include guest carts
# Email sequence
sequence:
- delay: 1h
template_id: 101
subject: "Forgot something?"
- delay: 24h
template_id: 102
subject: "Your cart is waiting"
include_discount: true
discount_percent: 10
- delay: 48h
template_id: 103
subject: "Last chance - items selling fast"
include_discount: true
discount_percent: 15
discount_expiry: 24h
# Stop conditions
stop_on:
- cart_recovered
- order_placed
- unsubscribe

Erweiterte Konfiguration

skills:
abandoned-cart:
# Segment-specific timing
timing:
vip_customers:
first_email: 30m
discount_threshold: 0 # Always include discount
new_customers:
first_email: 2h
discount_threshold: 50 # Discount only if cart > $50
repeat_customers:
first_email: 1h
discount_threshold: 100
# A/B testing
ab_testing:
enabled: true
variants:
- name: "urgency"
subject: "Items in your cart are selling fast!"
weight: 50
- name: "friendly"
subject: "Did you forget something?"
weight: 50
# Exclusions
exclude:
- email_domain: ["temp-mail.com", "disposable.com"]
- customer_tag: ["wholesale", "staff"]
- product_category: ["gift-cards"]

Trigger

cart_abandoned

Wird ausgelöst, wenn ein Warenkorb für die konfigurierte Zeitspanne inaktiv war.

Ereignisdaten

Parameter Type Description
cart_id required
string

Eindeutige Warenkorb-Kennung

customer_email required
string

E-Mail-Adresse der Kund:in

items required
array

Array der Warenkorbartikel mit Name, Preis, Menge, image_url

total required
number

Gesamtwert des Warenkorbs

currency optional
string

Währungscode (z. B. USD, EUR)

Default: USD
recovery_url required
string

URL zur Wiederherstellung des Warenkorbs

abandoned_at required
datetime

Zeitpunkt, zu dem der Warenkorb verlassen wurde

Beispiel-Payload:

{
"event": "cart_abandoned",
"timestamp": "2024-01-15T14:30:00Z",
"data": {
"cart_id": "cart_abc123",
"customer_email": "[email protected]",
"items": [
{
"id": "prod_123",
"name": "Premium Headphones",
"price": 199.99,
"quantity": 1,
"image_url": "https://cdn.example.com/headphones.jpg",
"variant": "Black"
},
{
"id": "prod_456",
"name": "Phone Case",
"price": 29.99,
"quantity": 2,
"image_url": "https://cdn.example.com/case.jpg"
}
],
"subtotal": 259.97,
"shipping": 0,
"tax": 20.80,
"total": 280.77,
"currency": "USD",
"recovery_url": "https://store.example.com/cart/recover/abc123",
"abandoned_at": "2024-01-15T14:00:00Z"
}
}

cart_recovered

Wird ausgelöst, wenn eine Kund:in zurückkehrt und den Checkout abschließt.

{
"event": "cart_recovered",
"timestamp": "2024-01-15T16:45:00Z",
"data": {
"cart_id": "cart_abc123",
"customer_email": "[email protected]",
"order_id": "order_789",
"recovered_via": "email_1", // Which email triggered recovery
"time_to_recover": "2h15m"
}
}

E-Mail-Vorlagen

Vorlagenvariablen

Verwenden Sie diese Variablen in Ihren Brevo-E-Mail-Vorlagen:

VariableBeschreibungBeispiel
params.FIRSTNAMEVorname der Kund:inJane
params.CART_URLRecovery-URL für den Warenkorbhttps://…
params.CART_TOTALFormatierter Warenkorbwert$280.77
params.ITEM_COUNTAnzahl der Artikel3
params.ITEMSJSON-Array der Artikel[…]
params.DISCOUNT_CODEGenerierter RabattcodeSAVE10-ABC
params.DISCOUNT_PERCENTRabatt in Prozent10
params.EXPIRY_DATEAblaufdatum des Rabatts17. Jan. 2024

Empfohlene E-Mail-Sequenz

E-Mail 1 (1 Stunde): Sanfte Erinnerung

  • Betreff: „Etwas vergessen, {{ params.FIRSTNAME }}?”
  • Fokus: An Warenkorbinhalt erinnern
  • Noch kein Rabatt

E-Mail 2 (24 Stunden): Dringlichkeit + Anreiz

  • Betreff: „Ihr Warenkorb wartet + 10 % Rabatt”
  • Fokus: Zeitlich begrenzter Rabatt
  • Rabattcode beifügen

E-Mail 3 (48 Stunden): Letzter Anstoß

  • Betreff: „Letzte Chance – 15 % Rabatt läuft bald aus”
  • Fokus: Knappheit + stärkerer Rabatt
  • 24-Stunden-Ablauf des Rabatts

Code-Beispiele

Warenkorbabbruch-Skill aktivieren

import { TajoClient } from '@tajo/sdk';
const tajo = new TajoClient({
apiKey: process.env.TAJO_API_KEY,
brevoApiKey: process.env.BREVO_API_KEY
});
await tajo.skills.enable('abandoned-cart', {
detection: {
inactivityThreshold: '30m',
minCartValue: 25
},
sequence: [
{ delay: '1h', templateId: 101 },
{ delay: '24h', templateId: 102, discountPercent: 10 },
{ delay: '48h', templateId: 103, discountPercent: 15 }
]
});

Warenkorbabbrüche erfassen

// Call this when cart activity is detected
await tajo.events.track('cart_updated', {
cartId: 'cart_abc123',
customerEmail: '[email protected]',
items: cartItems,
total: 280.77
});
// Call this when customer leaves without checkout
// (typically from a beforeunload event or session timeout)
await tajo.events.track('cart_abandoned', {
cartId: 'cart_abc123',
customerEmail: '[email protected]',
items: cartItems,
total: 280.77,
recoveryUrl: 'https://store.example.com/cart/recover/abc123'
});

Rabattcodes generieren

// Generate a unique discount code
const discount = await tajo.discounts.create({
type: 'percentage',
value: 10,
expiresIn: '7d',
usageLimit: 1,
prefix: 'SAVE10'
});
// discount.code => "SAVE10-ABC123"

Analytik

Verfolgen Sie die Performance der Warenkorb-Recovery:

KennzahlBeschreibung
AbbruchquoteAnteil der abgebrochenen Warenkörbe
Recovery-RateAnteil der zurückgewonnenen Warenkörbe
Zurückgewonnener UmsatzGesamtumsatz aus zurückgewonnenen Warenkörben
E-Mail-ÖffnungsrateAnteil geöffneter Recovery-E-Mails
E-Mail-CTRKlickrate bei Recovery-E-Mails
Zeit bis zur RecoveryDurchschnittliche Zeit vom Abbruch bis zum Kauf
const stats = await tajo.skills.getStats('abandoned-cart', {
period: '30d'
});
console.log(stats);
// {
// abandonmentRate: 68.5,
// recoveryRate: 12.3,
// revenueRecovered: 15420.50,
// emailsSent: 2340,
// emailOpenRate: 45.2,
// emailCtr: 8.7,
// avgTimeToRecovery: '4h32m'
// }

Best Practices

Das Timing zählt

Senden Sie die erste E-Mail innerhalb von 1–2 Stunden nach dem Abbruch. Nach 24 Stunden sinken die Recovery-Raten deutlich.

  1. Betreffzeilen personalisieren – Name und Warenkorbinhalt der Kund:in nutzen
  2. Warenkorbinhalt zeigen – Produktbilder in der E-Mail einbinden
  3. Dringlichkeit erzeugen – Auf geringe Bestände oder zeitlich begrenzte Rabatte hinweisen
  4. Recovery einfach machen – Ein-Klick-Links zur Warenkorb-Wiederherstellung
  5. Sequenz testen – A/B-Tests zu Timing, Betreffzeilen und Rabatten
  6. Abmeldungen respektieren – Sequenz sofort bei Abmeldung stoppen

Verwandte Skills

Nächste Schritte

  1. Warenkorb-Tracking einrichten auf Ihrer Plattform
  2. E-Mail-Vorlagen erstellen in Brevo
  3. Rabattcode-Integration konfigurieren
  4. Performance überwachen im Dashboard

Subscribe to updates

developer-docs

Drop your email or phone number — we'll send you what matters next.

AI-Assistent

Hallo! Fragen Sie mich alles über die Dokumentation.

Kostenlos mit Brevo starten