#!/usr/bin/env python3 """ Seed default email templates. Run: python scripts/seed_email_templates.py """ import contextlib import json import sys from pathlib import Path # Add project root to path sys.path.insert(0, str(Path(__file__).parent.parent)) # Register all models with SQLAlchemy so string-based relationships resolve for _mod in [ "app.modules.billing.models", "app.modules.inventory.models", "app.modules.cart.models", "app.modules.messaging.models", "app.modules.loyalty.models", "app.modules.catalog.models", "app.modules.customers.models", "app.modules.orders.models", "app.modules.marketplace.models", "app.modules.cms.models", ]: with contextlib.suppress(ImportError): __import__(_mod) from app.core.database import get_db from app.modules.messaging.models import EmailCategory, EmailTemplate # ============================================================================= # EMAIL TEMPLATES # ============================================================================= TEMPLATES = [ # ------------------------------------------------------------------------- # SIGNUP WELCOME # ------------------------------------------------------------------------- { "code": "signup_welcome", "language": "en", "name": "Signup Welcome", "description": "Sent to new stores after successful signup", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "first_name", "merchant_name", "email", "store_code", "login_url", "trial_days", "tier_name" ]), "subject": "Welcome to Orion, {{ first_name }}!", "body_html": """

Welcome to Orion!

Hi {{ first_name }},

Thank you for signing up for Orion! Your account for {{ merchant_name }} is now active.

Your Account Details

Store Code: {{ store_code }}

Plan: {{ tier_name }}

Trial Period: {{ trial_days }} days free

You can start managing your orders, inventory, and invoices right away:

Go to Dashboard

Getting Started

  1. Complete your merchant profile
  2. Connect your Letzshop API credentials
  3. Import your products
  4. Start syncing orders!

If you have any questions, just reply to this email or visit our help center.

Best regards,
The Orion Team

© 2024 Orion. Built for Luxembourg e-commerce.

""", "body_text": """Welcome to Orion! Hi {{ first_name }}, Thank you for signing up for Orion! Your account for {{ merchant_name }} is now active. Your Account Details: - Store Code: {{ store_code }} - Plan: {{ tier_name }} - Trial Period: {{ trial_days }} days free You can start managing your orders, inventory, and invoices right away. Go to Dashboard: {{ login_url }} Getting Started: 1. Complete your merchant profile 2. Connect your Letzshop API credentials 3. Import your products 4. Start syncing orders! If you have any questions, just reply to this email. Best regards, The Orion Team """, }, { "code": "signup_welcome", "language": "fr", "name": "Bienvenue après inscription", "description": "Envoyé aux nouveaux vendeurs après inscription", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "first_name", "merchant_name", "email", "store_code", "login_url", "trial_days", "tier_name" ]), "subject": "Bienvenue sur Orion, {{ first_name }} !", "body_html": """

Bienvenue sur Orion !

Bonjour {{ first_name }},

Merci de vous être inscrit sur Orion ! Votre compte pour {{ merchant_name }} est maintenant actif.

Détails de votre compte

Code vendeur : {{ store_code }}

Forfait : {{ tier_name }}

Période d'essai : {{ trial_days }} jours gratuits

Vous pouvez commencer à gérer vos commandes, stocks et factures dès maintenant :

Accéder au tableau de bord

Pour commencer

  1. Complétez votre profil d'entreprise
  2. Connectez vos identifiants API Letzshop
  3. Importez vos produits
  4. Commencez à synchroniser vos commandes !

Si vous avez des questions, répondez simplement à cet email.

Cordialement,
L'équipe Orion

© 2024 Orion. Conçu pour le e-commerce luxembourgeois.

""", "body_text": """Bienvenue sur Orion ! Bonjour {{ first_name }}, Merci de vous être inscrit sur Orion ! Votre compte pour {{ merchant_name }} est maintenant actif. Détails de votre compte : - Code vendeur : {{ store_code }} - Forfait : {{ tier_name }} - Période d'essai : {{ trial_days }} jours gratuits Accéder au tableau de bord : {{ login_url }} Pour commencer : 1. Complétez votre profil d'entreprise 2. Connectez vos identifiants API Letzshop 3. Importez vos produits 4. Commencez à synchroniser vos commandes ! Cordialement, L'équipe Orion """, }, { "code": "signup_welcome", "language": "de", "name": "Willkommen nach Anmeldung", "description": "An neue Verkäufer nach erfolgreicher Anmeldung gesendet", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "first_name", "merchant_name", "email", "store_code", "login_url", "trial_days", "tier_name" ]), "subject": "Willkommen bei Orion, {{ first_name }}!", "body_html": """

Willkommen bei Orion!

Hallo {{ first_name }},

Vielen Dank für Ihre Anmeldung bei Orion! Ihr Konto für {{ merchant_name }} ist jetzt aktiv.

Ihre Kontodaten

Verkäufercode: {{ store_code }}

Tarif: {{ tier_name }}

Testzeitraum: {{ trial_days }} Tage kostenlos

Sie können sofort mit der Verwaltung Ihrer Bestellungen, Bestände und Rechnungen beginnen:

Zum Dashboard

Erste Schritte

  1. Vervollständigen Sie Ihr Firmenprofil
  2. Verbinden Sie Ihre Letzshop API-Zugangsdaten
  3. Importieren Sie Ihre Produkte
  4. Starten Sie die Bestellungssynchronisierung!

Bei Fragen antworten Sie einfach auf diese E-Mail.

Mit freundlichen Grüßen,
Das Orion-Team

© 2024 Orion. Entwickelt für den luxemburgischen E-Commerce.

""", "body_text": """Willkommen bei Orion! Hallo {{ first_name }}, Vielen Dank für Ihre Anmeldung bei Orion! Ihr Konto für {{ merchant_name }} ist jetzt aktiv. Ihre Kontodaten: - Verkäufercode: {{ store_code }} - Tarif: {{ tier_name }} - Testzeitraum: {{ trial_days }} Tage kostenlos Zum Dashboard: {{ login_url }} Erste Schritte: 1. Vervollständigen Sie Ihr Firmenprofil 2. Verbinden Sie Ihre Letzshop API-Zugangsdaten 3. Importieren Sie Ihre Produkte 4. Starten Sie die Bestellungssynchronisierung! Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "signup_welcome", "language": "lb", "name": "Wëllkomm no der Umeldung", "description": "Un nei Verkeefer no erfollegräicher Umeldung geschéckt", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "first_name", "merchant_name", "email", "store_code", "login_url", "trial_days", "tier_name" ]), "subject": "Wëllkomm op Orion, {{ first_name }}!", "body_html": """

Wëllkomm op Orion!

Moien {{ first_name }},

Merci fir d'Umeldung op Orion! Äre Kont fir {{ merchant_name }} ass elo aktiv.

Är Kontdetailer

Verkeefer Code: {{ store_code }}

Plang: {{ tier_name }}

Testperiod: {{ trial_days }} Deeg gratis

Dir kënnt direkt ufänken Är Bestellungen, Lager a Rechnungen ze verwalten:

Zum Dashboard

Fir unzefänken

  1. Fëllt Äre Firmeprofil aus
  2. Verbindt Är Letzshop API Zougangsdaten
  3. Importéiert Är Produkter
  4. Fänkt un Bestellungen ze synchroniséieren!

Wann Dir Froen hutt, äntwert einfach op dës E-Mail.

Mat beschte Gréiss,
D'Orion Team

© 2024 Orion. Gemaach fir de lëtzebuergeschen E-Commerce.

""", "body_text": """Wëllkomm op Orion! Moien {{ first_name }}, Merci fir d'Umeldung op Orion! Äre Kont fir {{ merchant_name }} ass elo aktiv. Är Kontdetailer: - Verkeefer Code: {{ store_code }} - Plang: {{ tier_name }} - Testperiod: {{ trial_days }} Deeg gratis Zum Dashboard: {{ login_url }} Fir unzefänken: 1. Fëllt Äre Firmeprofil aus 2. Verbindt Är Letzshop API Zougangsdaten 3. Importéiert Är Produkter 4. Fänkt un Bestellungen ze synchroniséieren! Mat beschte Gréiss, D'Orion Team """, }, # ------------------------------------------------------------------------- # ORDER CONFIRMATION # ------------------------------------------------------------------------- { "code": "order_confirmation", "language": "en", "name": "Order Confirmation", "description": "Sent to customers after placing an order", "category": EmailCategory.ORDERS.value, "variables": json.dumps([ "customer_name", "order_number", "order_total", "order_items_count", "order_date", "shipping_address" ]), "subject": "Order Confirmation - {{ order_number }}", "body_html": """

Order Confirmed!

Hi {{ customer_name }},

Thank you for your order! We've received your order and it's being processed.

Order Details

Order Number: {{ order_number }}

Date: {{ order_date }}

Items: {{ order_items_count }}

Total: {{ order_total }}

Shipping Address

{{ shipping_address }}

You will receive another email when your order ships.

If you have any questions about your order, please contact us.

Thank you for shopping with us!
The Team

This is an automated email. Please do not reply directly.

""", "body_text": """Order Confirmed! Hi {{ customer_name }}, Thank you for your order! We've received your order and it's being processed. Order Details: - Order Number: {{ order_number }} - Date: {{ order_date }} - Items: {{ order_items_count }} - Total: {{ order_total }} Shipping Address: {{ shipping_address }} You will receive another email when your order ships. Thank you for shopping with us! """, }, { "code": "order_confirmation", "language": "fr", "name": "Confirmation de commande", "description": "Envoyé aux clients après avoir passé une commande", "category": EmailCategory.ORDERS.value, "variables": json.dumps([ "customer_name", "order_number", "order_total", "order_items_count", "order_date", "shipping_address" ]), "subject": "Confirmation de commande - {{ order_number }}", "body_html": """

Commande confirmée !

Bonjour {{ customer_name }},

Merci pour votre commande ! Nous l'avons bien reçue et elle est en cours de traitement.

Détails de la commande

Numéro de commande : {{ order_number }}

Date : {{ order_date }}

Articles : {{ order_items_count }}

Total : {{ order_total }}

Adresse de livraison

{{ shipping_address }}

Vous recevrez un autre email lors de l'expédition de votre commande.

Si vous avez des questions concernant votre commande, n'hésitez pas à nous contacter.

Merci pour votre achat !
L'équipe

""", "body_text": """Commande confirmée ! Bonjour {{ customer_name }}, Merci pour votre commande ! Nous l'avons bien reçue et elle est en cours de traitement. Détails de la commande : - Numéro de commande : {{ order_number }} - Date : {{ order_date }} - Articles : {{ order_items_count }} - Total : {{ order_total }} Adresse de livraison : {{ shipping_address }} Vous recevrez un autre email lors de l'expédition de votre commande. Merci pour votre achat ! """, }, { "code": "order_confirmation", "language": "de", "name": "Bestellbestätigung", "description": "An Kunden nach einer Bestellung gesendet", "category": EmailCategory.ORDERS.value, "variables": json.dumps([ "customer_name", "order_number", "order_total", "order_items_count", "order_date", "shipping_address" ]), "subject": "Bestellbestätigung - {{ order_number }}", "body_html": """

Bestellung bestätigt!

Hallo {{ customer_name }},

Vielen Dank für Ihre Bestellung! Wir haben Ihre Bestellung erhalten und sie wird bearbeitet.

Bestelldetails

Bestellnummer: {{ order_number }}

Datum: {{ order_date }}

Artikel: {{ order_items_count }}

Summe: {{ order_total }}

Lieferadresse

{{ shipping_address }}

Sie erhalten eine weitere E-Mail, sobald Ihre Bestellung versandt wird.

Bei Fragen zu Ihrer Bestellung kontaktieren Sie uns bitte.

Vielen Dank für Ihren Einkauf!
Das Team

""", "body_text": """Bestellung bestätigt! Hallo {{ customer_name }}, Vielen Dank für Ihre Bestellung! Wir haben Ihre Bestellung erhalten und sie wird bearbeitet. Bestelldetails: - Bestellnummer: {{ order_number }} - Datum: {{ order_date }} - Artikel: {{ order_items_count }} - Summe: {{ order_total }} Lieferadresse: {{ shipping_address }} Sie erhalten eine weitere E-Mail, sobald Ihre Bestellung versandt wird. Vielen Dank für Ihren Einkauf! """, }, { "code": "order_confirmation", "language": "lb", "name": "Bestellung Konfirmatioun", "description": "Un Clienten no enger Bestellung geschéckt", "category": EmailCategory.ORDERS.value, "variables": json.dumps([ "customer_name", "order_number", "order_total", "order_items_count", "order_date", "shipping_address" ]), "subject": "Bestellung Konfirmatioun - {{ order_number }}", "body_html": """

Bestellung confirméiert!

Moien {{ customer_name }},

Merci fir Är Bestellung! Mir hunn Är Bestellung kritt an si gëtt beaarbecht.

Bestelldetailer

Bestellnummer: {{ order_number }}

Datum: {{ order_date }}

Artikelen: {{ order_items_count }}

Total: {{ order_total }}

Liwweradress

{{ shipping_address }}

Dir kritt eng weider E-Mail wann Är Bestellung verschéckt gëtt.

Wann Dir Froen iwwer Är Bestellung hutt, kontaktéiert eis w.e.g.

Merci fir Ären Akaf!
D'Team

""", "body_text": """Bestellung confirméiert! Moien {{ customer_name }}, Merci fir Är Bestellung! Mir hunn Är Bestellung kritt an si gëtt beaarbecht. Bestelldetailer: - Bestellnummer: {{ order_number }} - Datum: {{ order_date }} - Artikelen: {{ order_items_count }} - Total: {{ order_total }} Liwweradress: {{ shipping_address }} Dir kritt eng weider E-Mail wann Är Bestellung verschéckt gëtt. Merci fir Ären Akaf! """, }, # ------------------------------------------------------------------------- # PASSWORD RESET # ------------------------------------------------------------------------- { "code": "password_reset", "language": "en", "name": "Password Reset", "description": "Sent to customers when they request a password reset", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "customer_name", "reset_link", "expiry_hours" ]), "subject": "Reset Your Password", "body_html": """

Reset Your Password

Hi {{ customer_name }},

We received a request to reset your password. Click the button below to create a new password:

Reset Password

This link will expire in {{ expiry_hours }} hour(s). If you didn't request this password reset, you can safely ignore this email.

If the button doesn't work, copy and paste this link into your browser:
{{ reset_link }}

Best regards,
The Team

This is an automated email. Please do not reply directly.

""", "body_text": """Reset Your Password Hi {{ customer_name }}, We received a request to reset your password. Click the link below to create a new password: {{ reset_link }} This link will expire in {{ expiry_hours }} hour(s). If you didn't request this password reset, you can safely ignore this email. Best regards, The Team """, }, { "code": "password_reset", "language": "fr", "name": "Reinitialisation du mot de passe", "description": "Envoye aux clients lorsqu'ils demandent une reinitialisation de mot de passe", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "customer_name", "reset_link", "expiry_hours" ]), "subject": "Reinitialiser votre mot de passe", "body_html": """

Reinitialiser votre mot de passe

Bonjour {{ customer_name }},

Nous avons recu une demande de reinitialisation de votre mot de passe. Cliquez sur le bouton ci-dessous pour creer un nouveau mot de passe :

Reinitialiser le mot de passe

Ce lien expirera dans {{ expiry_hours }} heure(s). Si vous n'avez pas demande cette reinitialisation, vous pouvez ignorer cet email.

Si le bouton ne fonctionne pas, copiez et collez ce lien dans votre navigateur :
{{ reset_link }}

Cordialement,
L'equipe

""", "body_text": """Reinitialiser votre mot de passe Bonjour {{ customer_name }}, Nous avons recu une demande de reinitialisation de votre mot de passe. Cliquez sur le lien ci-dessous pour creer un nouveau mot de passe : {{ reset_link }} Ce lien expirera dans {{ expiry_hours }} heure(s). Si vous n'avez pas demande cette reinitialisation, vous pouvez ignorer cet email. Cordialement, L'equipe """, }, { "code": "password_reset", "language": "de", "name": "Passwort zurucksetzen", "description": "An Kunden gesendet, wenn sie eine Passwortzurucksetzung anfordern", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "customer_name", "reset_link", "expiry_hours" ]), "subject": "Passwort zurucksetzen", "body_html": """

Passwort zurucksetzen

Hallo {{ customer_name }},

Wir haben eine Anfrage zur Zurucksetzung Ihres Passworts erhalten. Klicken Sie auf die Schaltflache unten, um ein neues Passwort zu erstellen:

Passwort zurucksetzen

Dieser Link lauft in {{ expiry_hours }} Stunde(n) ab. Wenn Sie diese Passwortzurucksetzung nicht angefordert haben, konnen Sie diese E-Mail ignorieren.

Wenn die Schaltflache nicht funktioniert, kopieren Sie diesen Link in Ihren Browser:
{{ reset_link }}

Mit freundlichen Grussen,
Das Team

""", "body_text": """Passwort zurucksetzen Hallo {{ customer_name }}, Wir haben eine Anfrage zur Zurucksetzung Ihres Passworts erhalten. Klicken Sie auf den Link unten, um ein neues Passwort zu erstellen: {{ reset_link }} Dieser Link lauft in {{ expiry_hours }} Stunde(n) ab. Wenn Sie diese Passwortzurucksetzung nicht angefordert haben, konnen Sie diese E-Mail ignorieren. Mit freundlichen Grussen, Das Team """, }, { "code": "password_reset", "language": "lb", "name": "Passwuert zrecksetzen", "description": "Un Clienten gescheckt wann si eng Passwuertzrecksetzung ufroen", "category": EmailCategory.AUTH.value, "variables": json.dumps([ "customer_name", "reset_link", "expiry_hours" ]), "subject": "Passwuert zrecksetzen", "body_html": """

Passwuert zrecksetzen

Moien {{ customer_name }},

Mir hunn eng Ufro kritt fir Aert Passwuert zreckzesetzen. Klickt op de Knäppchen hei drënner fir en neit Passwuert ze kreéieren:

Passwuert zrecksetzen

Dëse Link leeft an {{ expiry_hours }} Stonn(en) of. Wann Dir dës Passwuertzrecksetzung net ugefrot hutt, kënnt Dir dës E-Mail ignoréieren.

Wann de Knäppchen net fonctionnéiert, kopéiert dëse Link an Äre Browser:
{{ reset_link }}

Mat beschte Gréiss,
D'Team

""", "body_text": """Passwuert zrecksetzen Moien {{ customer_name }}, Mir hunn eng Ufro kritt fir Aert Passwuert zreckzesetzen. Klickt op de Link hei drënner fir en neit Passwuert ze kreéieren: {{ reset_link }} Dëse Link leeft an {{ expiry_hours }} Stonn(en) of. Wann Dir dës Passwuertzrecksetzung net ugefrot hutt, kënnt Dir dës E-Mail ignoréieren. Mat beschte Gréiss, D'Team """, }, # ------------------------------------------------------------------------- # PLATFORM-ONLY BILLING TEMPLATES # ------------------------------------------------------------------------- { "code": "subscription_welcome", "language": "en", "name": "Subscription Welcome", "description": "Sent to stores when they subscribe to a paid plan", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "billing_cycle", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "billing_cycle", "amount", "next_billing_date", "dashboard_url" ]), "subject": "Welcome to {{ tier_name }} - Subscription Confirmed", "body_html": """

Subscription Confirmed!

Hi {{ store_name }},

Thank you for subscribing to Orion! Your {{ tier_name }} subscription is now active.

Subscription Details

Plan: {{ tier_name }}

Billing Cycle: {{ billing_cycle }}

Amount: {{ amount }}

Next Billing Date: {{ next_billing_date }}

Go to Dashboard

If you have any questions about your subscription, please contact our support team.

Best regards,
The Orion Team

© 2024 Orion. All rights reserved.

""", "body_text": """Subscription Confirmed! Hi {{ store_name }}, Thank you for subscribing to Orion! Your {{ tier_name }} subscription is now active. Subscription Details: - Plan: {{ tier_name }} - Billing Cycle: {{ billing_cycle }} - Amount: {{ amount }} - Next Billing Date: {{ next_billing_date }} Go to Dashboard: {{ dashboard_url }} If you have any questions about your subscription, please contact our support team. Best regards, The Orion Team """, }, { "code": "subscription_welcome", "language": "fr", "name": "Bienvenue - Abonnement", "description": "Envoyé aux boutiques lors de la souscription à un plan payant", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "billing_cycle", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "billing_cycle", "amount", "next_billing_date", "dashboard_url" ]), "subject": "Bienvenue sur {{ tier_name }} - Abonnement confirmé", "body_html": """

Abonnement confirmé !

Bonjour {{ store_name }},

Merci de vous être abonné à Orion ! Votre abonnement {{ tier_name }} est maintenant actif.

Détails de l'abonnement

Plan : {{ tier_name }}

Cycle de facturation : {{ billing_cycle }}

Montant : {{ amount }}

Prochaine facturation : {{ next_billing_date }}

Accéder au tableau de bord

Si vous avez des questions concernant votre abonnement, veuillez contacter notre équipe de support.

Cordialement,
L'équipe Orion

© 2024 Orion. Tous droits réservés.

""", "body_text": """Abonnement confirmé ! Bonjour {{ store_name }}, Merci de vous être abonné à Orion ! Votre abonnement {{ tier_name }} est maintenant actif. Détails de l'abonnement : - Plan : {{ tier_name }} - Cycle de facturation : {{ billing_cycle }} - Montant : {{ amount }} - Prochaine facturation : {{ next_billing_date }} Accéder au tableau de bord : {{ dashboard_url }} Si vous avez des questions concernant votre abonnement, veuillez contacter notre équipe de support. Cordialement, L'équipe Orion """, }, { "code": "subscription_welcome", "language": "de", "name": "Willkommen - Abonnement", "description": "Wird an Shops gesendet, wenn sie ein kostenpflichtiges Abo abschließen", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "billing_cycle", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "billing_cycle", "amount", "next_billing_date", "dashboard_url" ]), "subject": "Willkommen bei {{ tier_name }} - Abonnement bestätigt", "body_html": """

Abonnement bestätigt!

Hallo {{ store_name }},

Vielen Dank für Ihr Abonnement bei Orion! Ihr {{ tier_name }}-Abonnement ist jetzt aktiv.

Abonnement-Details

Plan: {{ tier_name }}

Abrechnungszyklus: {{ billing_cycle }}

Betrag: {{ amount }}

Nächste Abrechnung: {{ next_billing_date }}

Zum Dashboard

Bei Fragen zu Ihrem Abonnement wenden Sie sich bitte an unser Support-Team.

Mit freundlichen Grüßen,
Das Orion-Team

© 2024 Orion. Alle Rechte vorbehalten.

""", "body_text": """Abonnement bestätigt! Hallo {{ store_name }}, Vielen Dank für Ihr Abonnement bei Orion! Ihr {{ tier_name }}-Abonnement ist jetzt aktiv. Abonnement-Details: - Plan: {{ tier_name }} - Abrechnungszyklus: {{ billing_cycle }} - Betrag: {{ amount }} - Nächste Abrechnung: {{ next_billing_date }} Zum Dashboard: {{ dashboard_url }} Bei Fragen zu Ihrem Abonnement wenden Sie sich bitte an unser Support-Team. Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "subscription_welcome", "language": "lb", "name": "Wëllkomm - Abonnement", "description": "Gëtt u Butteker geschéckt wann se en bezuelte Plang ofschléissen", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "billing_cycle", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "billing_cycle", "amount", "next_billing_date", "dashboard_url" ]), "subject": "Wëllkomm bei {{ tier_name }} - Abonnement bestätegt", "body_html": """

Abonnement bestätegt!

Moien {{ store_name }},

Merci fir Äert Abonnement bei Orion! Äert {{ tier_name }}-Abonnement ass elo aktiv.

Abonnement-Detailer

Plang: {{ tier_name }}

Ofrechnungszyklus: {{ billing_cycle }}

Betrag: {{ amount }}

Nächst Ofrechnung: {{ next_billing_date }}

Zum Dashboard

Wann Dir Froen zu Äerem Abonnement hutt, kontaktéiert w.e.g. eist Support-Team.

Mat frëndleche Gréiss,
D'Orion-Equipe

© 2024 Orion. All Rechter virbehalen.

""", "body_text": """Abonnement bestätegt! Moien {{ store_name }}, Merci fir Äert Abonnement bei Orion! Äert {{ tier_name }}-Abonnement ass elo aktiv. Abonnement-Detailer: - Plang: {{ tier_name }} - Ofrechnungszyklus: {{ billing_cycle }} - Betrag: {{ amount }} - Nächst Ofrechnung: {{ next_billing_date }} Zum Dashboard: {{ dashboard_url }} Wann Dir Froen zu Äerem Abonnement hutt, kontaktéiert w.e.g. eist Support-Team. Mat frëndleche Gréiss, D'Orion-Equipe """, }, { "code": "payment_failed", "language": "en", "name": "Payment Failed", "description": "Sent when a subscription payment fails", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "amount", "retry_date", "update_payment_url", "support_email" ]), "subject": "Action Required: Payment Failed for Your Subscription", "body_html": """

Payment Failed

Hi {{ store_name }},

We were unable to process your payment of {{ amount }} for your {{ tier_name }} subscription.

What happens next?

We'll automatically retry the payment on {{ retry_date }}.

To avoid any service interruption, please update your payment method.

Update Payment Method

If you need assistance, please contact us at {{ support_email }}.

Best regards,
The Orion Team

""", "body_text": """Payment Failed Hi {{ store_name }}, We were unable to process your payment of {{ amount }} for your {{ tier_name }} subscription. What happens next? - We'll automatically retry the payment on {{ retry_date }}. - To avoid any service interruption, please update your payment method. Update Payment Method: {{ update_payment_url }} If you need assistance, please contact us at {{ support_email }}. Best regards, The Orion Team """, }, { "code": "payment_failed", "language": "fr", "name": "Échec de paiement", "description": "Envoyé lorsqu'un paiement d'abonnement échoue", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "amount", "retry_date", "update_payment_url", "support_email" ]), "subject": "Action requise : Échec du paiement de votre abonnement", "body_html": """

Échec de paiement

Bonjour {{ store_name }},

Nous n'avons pas pu traiter votre paiement de {{ amount }} pour votre abonnement {{ tier_name }}.

Que se passe-t-il ensuite ?

Nous réessaierons automatiquement le paiement le {{ retry_date }}.

Pour éviter toute interruption de service, veuillez mettre à jour votre moyen de paiement.

Mettre à jour le moyen de paiement

Si vous avez besoin d'aide, contactez-nous à {{ support_email }}.

Cordialement,
L'équipe Orion

""", "body_text": """Échec de paiement Bonjour {{ store_name }}, Nous n'avons pas pu traiter votre paiement de {{ amount }} pour votre abonnement {{ tier_name }}. Que se passe-t-il ensuite ? - Nous réessaierons automatiquement le paiement le {{ retry_date }}. - Pour éviter toute interruption de service, veuillez mettre à jour votre moyen de paiement. Mettre à jour le moyen de paiement : {{ update_payment_url }} Si vous avez besoin d'aide, contactez-nous à {{ support_email }}. Cordialement, L'équipe Orion """, }, { "code": "payment_failed", "language": "de", "name": "Zahlung fehlgeschlagen", "description": "Wird gesendet, wenn eine Abonnementzahlung fehlschlägt", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "amount", "retry_date", "update_payment_url", "support_email" ]), "subject": "Handlungsbedarf: Zahlung für Ihr Abonnement fehlgeschlagen", "body_html": """

Zahlung fehlgeschlagen

Hallo {{ store_name }},

Wir konnten Ihre Zahlung von {{ amount }} für Ihr {{ tier_name }}-Abonnement nicht verarbeiten.

Was passiert als Nächstes?

Wir werden die Zahlung am {{ retry_date }} automatisch erneut versuchen.

Um eine Unterbrechung des Dienstes zu vermeiden, aktualisieren Sie bitte Ihre Zahlungsmethode.

Zahlungsmethode aktualisieren

Wenn Sie Hilfe benötigen, kontaktieren Sie uns unter {{ support_email }}.

Mit freundlichen Grüßen,
Das Orion-Team

""", "body_text": """Zahlung fehlgeschlagen Hallo {{ store_name }}, Wir konnten Ihre Zahlung von {{ amount }} für Ihr {{ tier_name }}-Abonnement nicht verarbeiten. Was passiert als Nächstes? - Wir werden die Zahlung am {{ retry_date }} automatisch erneut versuchen. - Um eine Unterbrechung des Dienstes zu vermeiden, aktualisieren Sie bitte Ihre Zahlungsmethode. Zahlungsmethode aktualisieren: {{ update_payment_url }} Wenn Sie Hilfe benötigen, kontaktieren Sie uns unter {{ support_email }}. Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "payment_failed", "language": "lb", "name": "Bezuelung fehlgeschloen", "description": "Gëtt geschéckt wann eng Abonnement-Bezuelung fehlschléit", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name", "amount"]), "variables": json.dumps([ "store_name", "tier_name", "amount", "retry_date", "update_payment_url", "support_email" ]), "subject": "Handlungsbedarf: Bezuelung fir Äert Abonnement fehlgeschloen", "body_html": """

Bezuelung fehlgeschloen

Moien {{ store_name }},

Mir konnten Är Bezuelung vun {{ amount }} fir Äert {{ tier_name }}-Abonnement net veraarbechten.

Wat geschitt als Nächst?

Mir probéieren d'Bezuelung den {{ retry_date }} automatesch nach eng Kéier.

Fir eng Ënnerbriechung vum Service ze vermeiden, aktualiséiert w.e.g. Är Bezuelmethod.

Bezuelmethod aktualiséieren

Wann Dir Hëllef braucht, kontaktéiert eis op {{ support_email }}.

Mat frëndleche Gréiss,
D'Orion-Equipe

""", "body_text": """Bezuelung fehlgeschloen Moien {{ store_name }}, Mir konnten Är Bezuelung vun {{ amount }} fir Äert {{ tier_name }}-Abonnement net veraarbechten. Wat geschitt als Nächst? - Mir probéieren d'Bezuelung den {{ retry_date }} automatesch nach eng Kéier. - Fir eng Ënnerbriechung vum Service ze vermeiden, aktualiséiert w.e.g. Är Bezuelmethod. Bezuelmethod aktualiséieren: {{ update_payment_url }} Wann Dir Hëllef braucht, kontaktéiert eis op {{ support_email }}. Mat frëndleche Gréiss, D'Orion-Equipe """, }, { "code": "subscription_cancelled", "language": "en", "name": "Subscription Cancelled", "description": "Sent when a subscription is cancelled", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name"]), "variables": json.dumps([ "store_name", "tier_name", "end_date", "reactivate_url" ]), "subject": "Your Orion Subscription Has Been Cancelled", "body_html": """

Subscription Cancelled

Hi {{ store_name }},

Your {{ tier_name }} subscription has been cancelled as requested.

What happens now?

You'll continue to have access to your {{ tier_name }} features until {{ end_date }}.

After that date, your account will be downgraded to the Free tier.

Changed your mind? You can reactivate your subscription at any time:

Reactivate Subscription

We're sorry to see you go. If there's anything we could have done better, please let us know.

Best regards,
The Orion Team

""", "body_text": """Subscription Cancelled Hi {{ store_name }}, Your {{ tier_name }} subscription has been cancelled as requested. What happens now? - You'll continue to have access to your {{ tier_name }} features until {{ end_date }}. - After that date, your account will be downgraded to the Free tier. Changed your mind? You can reactivate your subscription at any time: {{ reactivate_url }} We're sorry to see you go. If there's anything we could have done better, please let us know. Best regards, The Orion Team """, }, { "code": "subscription_cancelled", "language": "fr", "name": "Abonnement annulé", "description": "Envoyé lorsqu'un abonnement est annulé", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name"]), "variables": json.dumps([ "store_name", "tier_name", "end_date", "reactivate_url" ]), "subject": "Votre abonnement Orion a été annulé", "body_html": """

Abonnement annulé

Bonjour {{ store_name }},

Votre abonnement {{ tier_name }} a été annulé comme demandé.

Que se passe-t-il maintenant ?

Vous continuerez à avoir accès aux fonctionnalités {{ tier_name }} jusqu'au {{ end_date }}.

Après cette date, votre compte sera rétrogradé au niveau Gratuit.

Vous avez changé d'avis ? Vous pouvez réactiver votre abonnement à tout moment :

Réactiver l'abonnement

Nous sommes désolés de vous voir partir. Si nous pouvions faire mieux, n'hésitez pas à nous le dire.

Cordialement,
L'équipe Orion

""", "body_text": """Abonnement annulé Bonjour {{ store_name }}, Votre abonnement {{ tier_name }} a été annulé comme demandé. Que se passe-t-il maintenant ? - Vous continuerez à avoir accès aux fonctionnalités {{ tier_name }} jusqu'au {{ end_date }}. - Après cette date, votre compte sera rétrogradé au niveau Gratuit. Vous avez changé d'avis ? Vous pouvez réactiver votre abonnement à tout moment : {{ reactivate_url }} Nous sommes désolés de vous voir partir. Si nous pouvions faire mieux, n'hésitez pas à nous le dire. Cordialement, L'équipe Orion """, }, { "code": "subscription_cancelled", "language": "de", "name": "Abonnement gekündigt", "description": "Wird gesendet, wenn ein Abonnement gekündigt wird", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name"]), "variables": json.dumps([ "store_name", "tier_name", "end_date", "reactivate_url" ]), "subject": "Ihr Orion-Abonnement wurde gekündigt", "body_html": """

Abonnement gekündigt

Hallo {{ store_name }},

Ihr {{ tier_name }}-Abonnement wurde wie gewünscht gekündigt.

Was passiert jetzt?

Sie haben weiterhin Zugang zu den {{ tier_name }}-Funktionen bis zum {{ end_date }}.

Nach diesem Datum wird Ihr Konto auf die kostenlose Stufe herabgestuft.

Haben Sie es sich anders überlegt? Sie können Ihr Abonnement jederzeit reaktivieren:

Abonnement reaktivieren

Es tut uns leid, Sie gehen zu sehen. Wenn wir etwas besser machen könnten, lassen Sie es uns bitte wissen.

Mit freundlichen Grüßen,
Das Orion-Team

""", "body_text": """Abonnement gekündigt Hallo {{ store_name }}, Ihr {{ tier_name }}-Abonnement wurde wie gewünscht gekündigt. Was passiert jetzt? - Sie haben weiterhin Zugang zu den {{ tier_name }}-Funktionen bis zum {{ end_date }}. - Nach diesem Datum wird Ihr Konto auf die kostenlose Stufe herabgestuft. Haben Sie es sich anders überlegt? Sie können Ihr Abonnement jederzeit reaktivieren: {{ reactivate_url }} Es tut uns leid, Sie gehen zu sehen. Wenn wir etwas besser machen könnten, lassen Sie es uns bitte wissen. Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "subscription_cancelled", "language": "lb", "name": "Abonnement gekënnegt", "description": "Gëtt geschéckt wann en Abonnement gekënnegt gëtt", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "tier_name"]), "variables": json.dumps([ "store_name", "tier_name", "end_date", "reactivate_url" ]), "subject": "Äert Orion-Abonnement gouf gekënnegt", "body_html": """

Abonnement gekënnegt

Moien {{ store_name }},

Äert {{ tier_name }}-Abonnement gouf wéi gewënscht gekënnegt.

Wat geschitt elo?

Dir hutt weiderhin Zougang zu den {{ tier_name }}-Funktiounen bis den {{ end_date }}.

No deem Datum gëtt Äre Kont op de gratis Plang erofgesat.

Hutt Dir Iech anescht iwwerluecht? Dir kënnt Äert Abonnement zu all Moment reaktivéieren:

Abonnement reaktivéieren

Et deet eis leed Iech goen ze gesinn. Wann mir eppes besser kéinte maachen, sot eis w.e.g. Bescheed.

Mat frëndleche Gréiss,
D'Orion-Equipe

""", "body_text": """Abonnement gekënnegt Moien {{ store_name }}, Äert {{ tier_name }}-Abonnement gouf wéi gewënscht gekënnegt. Wat geschitt elo? - Dir hutt weiderhin Zougang zu den {{ tier_name }}-Funktiounen bis den {{ end_date }}. - No deem Datum gëtt Äre Kont op de gratis Plang erofgesat. Hutt Dir Iech anescht iwwerluecht? Dir kënnt Äert Abonnement zu all Moment reaktivéieren: {{ reactivate_url }} Et deet eis leed Iech goen ze gesinn. Wann mir eppes besser kéinte maachen, sot eis w.e.g. Bescheed. Mat frëndleche Gréiss, D'Orion-Equipe """, }, { "code": "trial_ending", "language": "en", "name": "Trial Ending Soon", "description": "Sent when a trial is about to end", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "days_remaining"]), "variables": json.dumps([ "store_name", "tier_name", "days_remaining", "trial_end_date", "upgrade_url", "features_list" ]), "subject": "Your Trial Ends in {{ days_remaining }} Days", "body_html": """

Your Trial is Ending Soon

Hi {{ store_name }},

Your {{ tier_name }} trial ends in {{ days_remaining }} days ({{ trial_end_date }}).

Don't lose these features:

{{ features_list }}

Subscribe now to continue using all {{ tier_name }} features without interruption:

Subscribe Now

Have questions? Reply to this email and we'll help you choose the right plan.

Best regards,
The Orion Team

""", "body_text": """Your Trial is Ending Soon Hi {{ store_name }}, Your {{ tier_name }} trial ends in {{ days_remaining }} days ({{ trial_end_date }}). Don't lose these features: {{ features_list }} Subscribe now to continue using all {{ tier_name }} features without interruption: {{ upgrade_url }} Have questions? Reply to this email and we'll help you choose the right plan. Best regards, The Orion Team """, }, { "code": "trial_ending", "language": "fr", "name": "Fin de période d'essai", "description": "Envoyé lorsqu'une période d'essai est sur le point de se terminer", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "days_remaining"]), "variables": json.dumps([ "store_name", "tier_name", "days_remaining", "trial_end_date", "upgrade_url", "features_list" ]), "subject": "Votre essai se termine dans {{ days_remaining }} jours", "body_html": """

Votre essai se termine bientôt

Bonjour {{ store_name }},

Votre essai {{ tier_name }} se termine dans {{ days_remaining }} jours ({{ trial_end_date }}).

Ne perdez pas ces fonctionnalités :

{{ features_list }}

Abonnez-vous maintenant pour continuer à utiliser toutes les fonctionnalités {{ tier_name }} sans interruption :

S'abonner maintenant

Des questions ? Répondez à cet email et nous vous aiderons à choisir le bon plan.

Cordialement,
L'équipe Orion

""", "body_text": """Votre essai se termine bientôt Bonjour {{ store_name }}, Votre essai {{ tier_name }} se termine dans {{ days_remaining }} jours ({{ trial_end_date }}). Ne perdez pas ces fonctionnalités : {{ features_list }} Abonnez-vous maintenant pour continuer à utiliser toutes les fonctionnalités {{ tier_name }} sans interruption : {{ upgrade_url }} Des questions ? Répondez à cet email et nous vous aiderons à choisir le bon plan. Cordialement, L'équipe Orion """, }, { "code": "trial_ending", "language": "de", "name": "Testphase endet bald", "description": "Wird gesendet, wenn eine Testphase bald endet", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "days_remaining"]), "variables": json.dumps([ "store_name", "tier_name", "days_remaining", "trial_end_date", "upgrade_url", "features_list" ]), "subject": "Ihre Testphase endet in {{ days_remaining }} Tagen", "body_html": """

Ihre Testphase endet bald

Hallo {{ store_name }},

Ihre {{ tier_name }}-Testphase endet in {{ days_remaining }} Tagen ({{ trial_end_date }}).

Verlieren Sie diese Funktionen nicht:

{{ features_list }}

Abonnieren Sie jetzt, um alle {{ tier_name }}-Funktionen ohne Unterbrechung weiter zu nutzen:

Jetzt abonnieren

Haben Sie Fragen? Antworten Sie auf diese E-Mail und wir helfen Ihnen, den richtigen Plan zu wählen.

Mit freundlichen Grüßen,
Das Orion-Team

""", "body_text": """Ihre Testphase endet bald Hallo {{ store_name }}, Ihre {{ tier_name }}-Testphase endet in {{ days_remaining }} Tagen ({{ trial_end_date }}). Verlieren Sie diese Funktionen nicht: {{ features_list }} Abonnieren Sie jetzt, um alle {{ tier_name }}-Funktionen ohne Unterbrechung weiter zu nutzen: {{ upgrade_url }} Haben Sie Fragen? Antworten Sie auf diese E-Mail und wir helfen Ihnen, den richtigen Plan zu wählen. Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "trial_ending", "language": "lb", "name": "Testphas endet geschwënn", "description": "Gëtt geschéckt wann eng Testphas geschwënn ofleeft", "category": EmailCategory.BILLING.value, "is_platform_only": True, "required_variables": json.dumps(["store_name", "days_remaining"]), "variables": json.dumps([ "store_name", "tier_name", "days_remaining", "trial_end_date", "upgrade_url", "features_list" ]), "subject": "Är Testphas leeft a(n) {{ days_remaining }} Deeg of", "body_html": """

Är Testphas endet geschwënn

Moien {{ store_name }},

Är {{ tier_name }}-Testphas leeft a(n) {{ days_remaining }} Deeg of ({{ trial_end_date }}).

Verléiert dës Funktiounen net:

{{ features_list }}

Abonnéiert Iech elo fir all {{ tier_name }}-Funktiounen ouni Ënnerbriechung weider ze notzen:

Elo abonnéieren

Hutt Dir Froen? Äntwert op dës E-Mail a mir hëllefen Iech de richtege Plang ze wielen.

Mat frëndleche Gréiss,
D'Orion-Equipe

""", "body_text": """Är Testphas endet geschwënn Moien {{ store_name }}, Är {{ tier_name }}-Testphas leeft a(n) {{ days_remaining }} Deeg of ({{ trial_end_date }}). Verléiert dës Funktiounen net: {{ features_list }} Abonnéiert Iech elo fir all {{ tier_name }}-Funktiounen ouni Ënnerbriechung weider ze notzen: {{ upgrade_url }} Hutt Dir Froen? Äntwert op dës E-Mail a mir hëllefen Iech de richtege Plang ze wielen. Mat frëndleche Gréiss, D'Orion-Equipe """, }, { "code": "team_invite", "language": "en", "name": "Team Member Invitation", "description": "Sent when a store invites a team member", "category": EmailCategory.SYSTEM.value, "is_platform_only": False, "required_variables": json.dumps(["invitee_name", "inviter_name", "store_name", "accept_url"]), "variables": json.dumps([ "invitee_name", "inviter_name", "store_name", "role", "accept_url", "expires_in_days" ]), "subject": "{{ inviter_name }} invited you to join {{ store_name }} on Orion", "body_html": """

You've Been Invited!

Hi {{ invitee_name }},

{{ inviter_name }} has invited you to join {{ store_name }} as a team member on Orion.

Invitation Details

Store: {{ store_name }}

Role: {{ role }}

Invited by: {{ inviter_name }}

Accept Invitation

This invitation will expire in {{ expires_in_days }} days.

If you weren't expecting this invitation, you can safely ignore this email.

Best regards,
The Orion Team

""", "body_text": """You've Been Invited! Hi {{ invitee_name }}, {{ inviter_name }} has invited you to join {{ store_name }} as a team member on Orion. Invitation Details: - Store: {{ store_name }} - Role: {{ role }} - Invited by: {{ inviter_name }} Accept Invitation: {{ accept_url }} This invitation will expire in {{ expires_in_days }} days. If you weren't expecting this invitation, you can safely ignore this email. Best regards, The Orion Team """, }, { "code": "team_invite", "language": "fr", "name": "Invitation d'équipe", "description": "Envoyé lorsqu'une boutique invite un membre de l'équipe", "category": EmailCategory.SYSTEM.value, "is_platform_only": False, "required_variables": json.dumps(["invitee_name", "inviter_name", "store_name", "accept_url"]), "variables": json.dumps([ "invitee_name", "inviter_name", "store_name", "role", "accept_url", "expires_in_days" ]), "subject": "{{ inviter_name }} vous invite à rejoindre {{ store_name }} sur Orion", "body_html": """

Vous êtes invité(e) !

Bonjour {{ invitee_name }},

{{ inviter_name }} vous a invité(e) à rejoindre {{ store_name }} en tant que membre de l'équipe sur Orion.

Détails de l'invitation

Boutique : {{ store_name }}

Rôle : {{ role }}

Invité par : {{ inviter_name }}

Accepter l'invitation

Cette invitation expire dans {{ expires_in_days }} jours.

Si vous n'attendiez pas cette invitation, vous pouvez ignorer cet email.

Cordialement,
L'équipe Orion

""", "body_text": """Vous êtes invité(e) ! Bonjour {{ invitee_name }}, {{ inviter_name }} vous a invité(e) à rejoindre {{ store_name }} en tant que membre de l'équipe sur Orion. Détails de l'invitation : - Boutique : {{ store_name }} - Rôle : {{ role }} - Invité par : {{ inviter_name }} Accepter l'invitation : {{ accept_url }} Cette invitation expire dans {{ expires_in_days }} jours. Si vous n'attendiez pas cette invitation, vous pouvez ignorer cet email. Cordialement, L'équipe Orion """, }, { "code": "team_invite", "language": "de", "name": "Team-Einladung", "description": "Wird gesendet, wenn ein Shop ein Teammitglied einlädt", "category": EmailCategory.SYSTEM.value, "is_platform_only": False, "required_variables": json.dumps(["invitee_name", "inviter_name", "store_name", "accept_url"]), "variables": json.dumps([ "invitee_name", "inviter_name", "store_name", "role", "accept_url", "expires_in_days" ]), "subject": "{{ inviter_name }} hat Sie eingeladen, {{ store_name }} auf Orion beizutreten", "body_html": """

Sie wurden eingeladen!

Hallo {{ invitee_name }},

{{ inviter_name }} hat Sie eingeladen, {{ store_name }} als Teammitglied auf Orion beizutreten.

Einladungsdetails

Shop: {{ store_name }}

Rolle: {{ role }}

Eingeladen von: {{ inviter_name }}

Einladung annehmen

Diese Einladung läuft in {{ expires_in_days }} Tagen ab.

Wenn Sie diese Einladung nicht erwartet haben, können Sie diese E-Mail ignorieren.

Mit freundlichen Grüßen,
Das Orion-Team

""", "body_text": """Sie wurden eingeladen! Hallo {{ invitee_name }}, {{ inviter_name }} hat Sie eingeladen, {{ store_name }} als Teammitglied auf Orion beizutreten. Einladungsdetails: - Shop: {{ store_name }} - Rolle: {{ role }} - Eingeladen von: {{ inviter_name }} Einladung annehmen: {{ accept_url }} Diese Einladung läuft in {{ expires_in_days }} Tagen ab. Wenn Sie diese Einladung nicht erwartet haben, können Sie diese E-Mail ignorieren. Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "team_invite", "language": "lb", "name": "Team-Invitatioun", "description": "Gëtt geschéckt wann e Buttek en Teammember invitéiert", "category": EmailCategory.SYSTEM.value, "is_platform_only": False, "required_variables": json.dumps(["invitee_name", "inviter_name", "store_name", "accept_url"]), "variables": json.dumps([ "invitee_name", "inviter_name", "store_name", "role", "accept_url", "expires_in_days" ]), "subject": "{{ inviter_name }} huet Iech invitéiert, {{ store_name }} op Orion bäizetrieden", "body_html": """

Dir sidd invitéiert!

Moien {{ invitee_name }},

{{ inviter_name }} huet Iech invitéiert, {{ store_name }} als Teammember op Orion bäizetrieden.

Invitatiounsdetailer

Buttek: {{ store_name }}

Roll: {{ role }}

Invitéiert vun: {{ inviter_name }}

Invitatioun unhuelen

Dës Invitatioun leeft a(n) {{ expires_in_days }} Deeg of.

Wann Dir dës Invitatioun net erwaart hutt, kënnt Dir dës E-Mail ignoréieren.

Mat frëndleche Gréiss,
D'Orion-Equipe

""", "body_text": """Dir sidd invitéiert! Moien {{ invitee_name }}, {{ inviter_name }} huet Iech invitéiert, {{ store_name }} als Teammember op Orion bäizetrieden. Invitatiounsdetailer: - Buttek: {{ store_name }} - Roll: {{ role }} - Invitéiert vun: {{ inviter_name }} Invitatioun unhuelen: {{ accept_url }} Dës Invitatioun leeft a(n) {{ expires_in_days }} Deeg of. Wann Dir dës Invitatioun net erwaart hutt, kënnt Dir dës E-Mail ignoréieren. Mat frëndleche Gréiss, D'Orion-Equipe """, }, # ------------------------------------------------------------------------- # EMAIL VERIFICATION # ------------------------------------------------------------------------- { "code": "email_verification", "language": "en", "name": "Email Verification", "description": "Sent to users to verify their email address", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "verification_link", "expiry_hours", "platform_name" ]), "subject": "Verify Your Email Address", "body_html": """

Verify Your Email

Hi {{ first_name }},

Please verify your email address by clicking the button below:

Verify Email

This link will expire in {{ expiry_hours }} hours. If you didn't create an account, you can safely ignore this email.

If the button doesn't work, copy and paste this link into your browser:
{{ verification_link }}

Best regards,
The {{ platform_name }} Team

This is an automated email. Please do not reply directly.

""", "body_text": """Verify Your Email Hi {{ first_name }}, Please verify your email address by clicking the link below: {{ verification_link }} This link will expire in {{ expiry_hours }} hours. If you didn't create an account, you can safely ignore this email. Best regards, The {{ platform_name }} Team """, }, { "code": "email_verification", "language": "fr", "name": "Verification d'email", "description": "Envoye aux utilisateurs pour verifier leur adresse email", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "verification_link", "expiry_hours", "platform_name" ]), "subject": "Verifiez votre adresse email", "body_html": """

Verifiez votre email

Bonjour {{ first_name }},

Veuillez verifier votre adresse email en cliquant sur le bouton ci-dessous :

Verifier l'email

Ce lien expirera dans {{ expiry_hours }} heures. Si vous n'avez pas cree de compte, vous pouvez ignorer cet email.

Si le bouton ne fonctionne pas, copiez et collez ce lien dans votre navigateur :
{{ verification_link }}

Cordialement,
L'equipe {{ platform_name }}

""", "body_text": """Verifiez votre email Bonjour {{ first_name }}, Veuillez verifier votre adresse email en cliquant sur le lien ci-dessous : {{ verification_link }} Ce lien expirera dans {{ expiry_hours }} heures. Si vous n'avez pas cree de compte, vous pouvez ignorer cet email. Cordialement, L'equipe {{ platform_name }} """, }, { "code": "email_verification", "language": "de", "name": "E-Mail-Verifizierung", "description": "An Benutzer gesendet, um ihre E-Mail-Adresse zu verifizieren", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "verification_link", "expiry_hours", "platform_name" ]), "subject": "Bestatigen Sie Ihre E-Mail-Adresse", "body_html": """

E-Mail bestatigen

Hallo {{ first_name }},

Bitte bestatigen Sie Ihre E-Mail-Adresse, indem Sie auf die Schaltflache unten klicken:

E-Mail bestatigen

Dieser Link lauft in {{ expiry_hours }} Stunden ab. Wenn Sie kein Konto erstellt haben, konnen Sie diese E-Mail ignorieren.

Wenn die Schaltflache nicht funktioniert, kopieren Sie diesen Link in Ihren Browser:
{{ verification_link }}

Mit freundlichen Grussen,
Das {{ platform_name }}-Team

""", "body_text": """E-Mail bestatigen Hallo {{ first_name }}, Bitte bestatigen Sie Ihre E-Mail-Adresse, indem Sie auf den Link unten klicken: {{ verification_link }} Dieser Link lauft in {{ expiry_hours }} Stunden ab. Wenn Sie kein Konto erstellt haben, konnen Sie diese E-Mail ignorieren. Mit freundlichen Grussen, Das {{ platform_name }}-Team """, }, { "code": "email_verification", "language": "lb", "name": "E-Mail Verifizéierung", "description": "Un Benotzer gescheckt fir hir E-Mail-Adress ze verifizéieren", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "verification_link", "expiry_hours", "platform_name" ]), "subject": "Bestategt Är E-Mail-Adress", "body_html": """

E-Mail bestategen

Moien {{ first_name }},

Bestategt w.e.g. Är E-Mail-Adress andeems Dir op de Knäppchen hei drënner klickt:

E-Mail bestategen

Dese Link leeft an {{ expiry_hours }} Stonnen of. Wann Dir kee Kont erstallt hutt, kennt Dir des E-Mail ignoréieren.

Wann de Knappchen net fonctionnéiert, kopéiert dese Link an Are Browser:
{{ verification_link }}

Mat beschte Greiss,
D'{{ platform_name }} Team

""", "body_text": """E-Mail bestategen Moien {{ first_name }}, Bestategt w.e.g. Ar E-Mail-Adress andeems Dir op de Link hei drenner klickt: {{ verification_link }} Dese Link leeft an {{ expiry_hours }} Stonnen of. Wann Dir kee Kont erstallt hutt, kennt Dir des E-Mail ignoréieren. Mat beschte Greiss, D'{{ platform_name }} Team """, }, # ------------------------------------------------------------------------- # MERCHANT PASSWORD RESET # ------------------------------------------------------------------------- { "code": "merchant_password_reset", "language": "en", "name": "Merchant Password Reset", "description": "Sent to merchants/store users when they request a password reset", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "reset_link", "expiry_hours", "platform_name" ]), "subject": "Reset Your Password", "body_html": """

Reset Your Password

Hi {{ first_name }},

We received a request to reset your password. Click the button below to create a new password:

Reset Password

This link will expire in {{ expiry_hours }} hour(s). If you didn't request this password reset, you can safely ignore this email.

If the button doesn't work, copy and paste this link into your browser:
{{ reset_link }}

Best regards,
The {{ platform_name }} Team

This is an automated email. Please do not reply directly.

""", "body_text": """Reset Your Password Hi {{ first_name }}, We received a request to reset your password. Click the link below to create a new password: {{ reset_link }} This link will expire in {{ expiry_hours }} hour(s). If you didn't request this password reset, you can safely ignore this email. Best regards, The {{ platform_name }} Team """, }, { "code": "merchant_password_reset", "language": "fr", "name": "Reinitialisation mot de passe marchand", "description": "Envoye aux marchands lorsqu'ils demandent une reinitialisation de mot de passe", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "reset_link", "expiry_hours", "platform_name" ]), "subject": "Reinitialiser votre mot de passe", "body_html": """

Reinitialiser votre mot de passe

Bonjour {{ first_name }},

Nous avons recu une demande de reinitialisation de votre mot de passe. Cliquez sur le bouton ci-dessous pour creer un nouveau mot de passe :

Reinitialiser le mot de passe

Ce lien expirera dans {{ expiry_hours }} heure(s). Si vous n'avez pas demande cette reinitialisation, vous pouvez ignorer cet email.

Si le bouton ne fonctionne pas, copiez et collez ce lien dans votre navigateur :
{{ reset_link }}

Cordialement,
L'equipe {{ platform_name }}

""", "body_text": """Reinitialiser votre mot de passe Bonjour {{ first_name }}, Nous avons recu une demande de reinitialisation de votre mot de passe. Cliquez sur le lien ci-dessous : {{ reset_link }} Ce lien expirera dans {{ expiry_hours }} heure(s). Si vous n'avez pas demande cette reinitialisation, vous pouvez ignorer cet email. Cordialement, L'equipe {{ platform_name }} """, }, { "code": "merchant_password_reset", "language": "de", "name": "Handler Passwort zurucksetzen", "description": "An Handler gesendet, wenn sie eine Passwortzurucksetzung anfordern", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "reset_link", "expiry_hours", "platform_name" ]), "subject": "Passwort zurucksetzen", "body_html": """

Passwort zurucksetzen

Hallo {{ first_name }},

Wir haben eine Anfrage zur Zurucksetzung Ihres Passworts erhalten. Klicken Sie auf die Schaltflache unten, um ein neues Passwort zu erstellen:

Passwort zurucksetzen

Dieser Link lauft in {{ expiry_hours }} Stunde(n) ab. Wenn Sie diese Passwortzurucksetzung nicht angefordert haben, konnen Sie diese E-Mail ignorieren.

Wenn die Schaltflache nicht funktioniert, kopieren Sie diesen Link in Ihren Browser:
{{ reset_link }}

Mit freundlichen Grussen,
Das {{ platform_name }}-Team

""", "body_text": """Passwort zurucksetzen Hallo {{ first_name }}, Wir haben eine Anfrage zur Zurucksetzung Ihres Passworts erhalten. Klicken Sie auf den Link unten: {{ reset_link }} Dieser Link lauft in {{ expiry_hours }} Stunde(n) ab. Wenn Sie diese Passwortzurucksetzung nicht angefordert haben, konnen Sie diese E-Mail ignorieren. Mit freundlichen Grussen, Das {{ platform_name }}-Team """, }, { "code": "merchant_password_reset", "language": "lb", "name": "Handler Passwuert zrecksetzen", "description": "Un Handler gescheckt wann si eng Passwuertzrecksetzung ufroen", "category": EmailCategory.AUTH.value, "is_platform_only": False, "variables": json.dumps([ "first_name", "reset_link", "expiry_hours", "platform_name" ]), "subject": "Passwuert zrecksetzen", "body_html": """

Passwuert zrecksetzen

Moien {{ first_name }},

Mir hunn eng Ufro kritt fir Aert Passwuert zreckzesetzen. Klickt op de Knappchen hei drenner fir en neit Passwuert ze kreéieren:

Passwuert zrecksetzen

Dese Link leeft an {{ expiry_hours }} Stonn(en) of. Wann Dir des Passwuertzrecksetzung net ugefrot hutt, kennt Dir des E-Mail ignoréieren.

Wann de Knappchen net fonctionnéiert, kopéiert dese Link an Are Browser:
{{ reset_link }}

Mat beschte Greiss,
D'{{ platform_name }} Team

""", "body_text": """Passwuert zrecksetzen Moien {{ first_name }}, Mir hunn eng Ufro kritt fir Aert Passwuert zreckzesetzen. Klickt op de Link hei drenner: {{ reset_link }} Dese Link leeft an {{ expiry_hours }} Stonn(en) of. Wann Dir des Passwuertzrecksetzung net ugefrot hutt, kennt Dir des E-Mail ignoréieren. Mat beschte Greiss, D'{{ platform_name }} Team """, }, # ------------------------------------------------------------------------- # TEAM INVITATION # ------------------------------------------------------------------------- { "code": "team_invitation", "language": "en", "name": "Team Invitation", "description": "Sent when a team member is invited to a store", "category": EmailCategory.SYSTEM.value, "variables": json.dumps([ "invited_by_name", "store_name", "role_name", "acceptance_link", "expiry_days" ]), "subject": "You've been invited to join {{ store_name }}", "body_html": """

Team Invitation

Hello,

{{ invited_by_name }} has invited you to join {{ store_name }} as a {{ role_name }}.

Accept Invitation

This invitation expires in {{ expiry_days }} days. If you did not expect this invitation, you can safely ignore this email.

Best regards,
The Orion Team

© 2024 Orion. Built for Luxembourg e-commerce.

""", "body_text": """Team Invitation Hello, {{ invited_by_name }} has invited you to join {{ store_name }} as a {{ role_name }}. Accept Invitation: {{ acceptance_link }} This invitation expires in {{ expiry_days }} days. If you did not expect this invitation, you can safely ignore this email. Best regards, The Orion Team """, }, { "code": "team_invitation", "language": "fr", "name": "Invitation d'équipe", "description": "Envoyé lorsqu'un membre est invité à rejoindre une boutique", "category": EmailCategory.SYSTEM.value, "variables": json.dumps([ "invited_by_name", "store_name", "role_name", "acceptance_link", "expiry_days" ]), "subject": "Vous avez été invité(e) à rejoindre {{ store_name }}", "body_html": """

Invitation d'équipe

Bonjour,

{{ invited_by_name }} vous a invité(e) à rejoindre {{ store_name }} en tant que {{ role_name }}.

Accepter l'invitation

Cette invitation expire dans {{ expiry_days }} jours. Si vous n'attendiez pas cette invitation, vous pouvez ignorer cet email.

Cordialement,
L'équipe Orion

© 2024 Orion. Conçu pour le e-commerce luxembourgeois.

""", "body_text": """Invitation d'équipe Bonjour, {{ invited_by_name }} vous a invité(e) à rejoindre {{ store_name }} en tant que {{ role_name }}. Accepter l'invitation : {{ acceptance_link }} Cette invitation expire dans {{ expiry_days }} jours. Si vous n'attendiez pas cette invitation, vous pouvez ignorer cet email. Cordialement, L'équipe Orion """, }, { "code": "team_invitation", "language": "de", "name": "Teameinladung", "description": "Gesendet wenn ein Teammitglied zu einem Shop eingeladen wird", "category": EmailCategory.SYSTEM.value, "variables": json.dumps([ "invited_by_name", "store_name", "role_name", "acceptance_link", "expiry_days" ]), "subject": "Sie wurden eingeladen, {{ store_name }} beizutreten", "body_html": """

Teameinladung

Hallo,

{{ invited_by_name }} hat Sie eingeladen, {{ store_name }} als {{ role_name }} beizutreten.

Einladung annehmen

Diese Einladung läuft in {{ expiry_days }} Tagen ab. Wenn Sie diese Einladung nicht erwartet haben, können Sie diese E-Mail ignorieren.

Mit freundlichen Grüßen,
Das Orion-Team

© 2024 Orion. Entwickelt für den luxemburgischen E-Commerce.

""", "body_text": """Teameinladung Hallo, {{ invited_by_name }} hat Sie eingeladen, {{ store_name }} als {{ role_name }} beizutreten. Einladung annehmen: {{ acceptance_link }} Diese Einladung läuft in {{ expiry_days }} Tagen ab. Wenn Sie diese Einladung nicht erwartet haben, können Sie diese E-Mail ignorieren. Mit freundlichen Grüßen, Das Orion-Team """, }, { "code": "team_invitation", "language": "lb", "name": "Team-Invitatioun", "description": "Gëtt geschéckt wann en Teammember an e Buttek invitéiert gëtt", "category": EmailCategory.SYSTEM.value, "variables": json.dumps([ "invited_by_name", "store_name", "role_name", "acceptance_link", "expiry_days" ]), "subject": "Dir sidd invitéiert, {{ store_name }} bäizetrieden", "body_html": """

Team-Invitatioun

Moien,

{{ invited_by_name }} huet Iech invitéiert, {{ store_name }} als {{ role_name }} bäizetrieden.

Invitatioun unhuelen

Dës Invitatioun leeft a(n) {{ expiry_days }} Deeg of. Wann Dir dës Invitatioun net erwaart hutt, kënnt Dir dës E-Mail ignoréieren.

Mat frëndleche Gréiss,
D'Orion-Equipe

© 2024 Orion. Gebaut fir de lëtzebuergeschen E-Commerce.

""", "body_text": """Team-Invitatioun Moien, {{ invited_by_name }} huet Iech invitéiert, {{ store_name }} als {{ role_name }} bäizetrieden. Invitatioun unhuelen: {{ acceptance_link }} Dës Invitatioun leeft a(n) {{ expiry_days }} Deeg of. Wann Dir dës Invitatioun net erwaart hutt, kënnt Dir dës E-Mail ignoréieren. Mat frëndleche Gréiss, D'Orion-Equipe """, }, ] def seed_templates(): """Seed email templates into database.""" db = next(get_db()) try: created = 0 updated = 0 for template_data in TEMPLATES: # Set defaults for new fields template_data.setdefault("is_platform_only", False) template_data.setdefault("required_variables", None) # Check if template already exists existing = ( db.query(EmailTemplate) .filter( EmailTemplate.code == template_data["code"], EmailTemplate.language == template_data["language"], ) .first() ) if existing: # Update existing template for key, value in template_data.items(): setattr(existing, key, value) updated += 1 platform_only_tag = " [platform-only]" if template_data.get("is_platform_only") else "" print(f"Updated: {template_data['code']} ({template_data['language']}){platform_only_tag}") else: # Create new template template = EmailTemplate(**template_data) db.add(template) # noqa: PERF006 created += 1 platform_only_tag = " [platform-only]" if template_data.get("is_platform_only") else "" print(f"Created: {template_data['code']} ({template_data['language']}){platform_only_tag}") db.commit() print(f"\nDone! Created: {created}, Updated: {updated}") except Exception as e: db.rollback() print(f"Error: {e}") raise finally: db.close() if __name__ == "__main__": seed_templates()