This commit completes the migration to a fully module-driven architecture: ## Models Migration - Moved all domain models from models/database/ to their respective modules: - tenancy: User, Admin, Vendor, Company, Platform, VendorDomain, etc. - cms: MediaFile, VendorTheme - messaging: Email, VendorEmailSettings, VendorEmailTemplate - core: AdminMenuConfig - models/database/ now only contains Base and TimestampMixin (infrastructure) ## Schemas Migration - Moved all domain schemas from models/schema/ to their respective modules: - tenancy: company, vendor, admin, team, vendor_domain - cms: media, image, vendor_theme - messaging: email - models/schema/ now only contains base.py and auth.py (infrastructure) ## Routes Migration - Moved admin routes from app/api/v1/admin/ to modules: - menu_config.py -> core module - modules.py -> tenancy module - module_config.py -> tenancy module - app/api/v1/admin/ now only aggregates auto-discovered module routes ## Menu System - Implemented module-driven menu system with MenuDiscoveryService - Extended FrontendType enum: PLATFORM, ADMIN, VENDOR, STOREFRONT - Added MenuItemDefinition and MenuSectionDefinition dataclasses - Each module now defines its own menu items in definition.py - MenuService integrates with MenuDiscoveryService for template rendering ## Documentation - Updated docs/architecture/models-structure.md - Updated docs/architecture/menu-management.md - Updated architecture validation rules for new exceptions ## Architecture Validation - Updated MOD-019 rule to allow base.py in models/schema/ - Created core module exceptions.py and schemas/ directory - All validation errors resolved (only warnings remain) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
110 lines
3.7 KiB
JSON
110 lines
3.7 KiB
JSON
{
|
|
"title": "Abrechnung & Abonnements",
|
|
"description": "Abonnementstufen, Rechnungshistorie und Zahlungen verwalten",
|
|
"subscription": {
|
|
"title": "Abonnement",
|
|
"current_tier": "Aktuelle Stufe",
|
|
"status": "Status",
|
|
"statuses": {
|
|
"trial": "Testphase",
|
|
"active": "Aktiv",
|
|
"past_due": "Überfällig",
|
|
"cancelled": "Gekündigt",
|
|
"expired": "Abgelaufen"
|
|
},
|
|
"trial_ends": "Testphase endet",
|
|
"period_ends": "Periode endet",
|
|
"cancelled_at": "Gekündigt am",
|
|
"cancellation_reason": "Kündigungsgrund"
|
|
},
|
|
"tiers": {
|
|
"title": "Abonnementstufen",
|
|
"subtitle": "Preisstufen und Funktionen verwalten",
|
|
"essential": "Essential",
|
|
"professional": "Professional",
|
|
"business": "Business",
|
|
"enterprise": "Enterprise",
|
|
"create": "Stufe erstellen",
|
|
"edit": "Stufe bearbeiten",
|
|
"features": "Funktionen",
|
|
"limits": "Limits",
|
|
"pricing": "Preisgestaltung",
|
|
"monthly": "Monatlich",
|
|
"annual": "Jährlich",
|
|
"per_month": "/Monat",
|
|
"per_year": "/Jahr",
|
|
"unlimited": "Unbegrenzt",
|
|
"orders_per_month": "Bestellungen/Monat",
|
|
"products_limit": "Produkte",
|
|
"team_members": "Teammitglieder"
|
|
},
|
|
"usage": {
|
|
"title": "Nutzung",
|
|
"orders": "Bestellungen",
|
|
"products": "Produkte",
|
|
"team": "Teammitglieder",
|
|
"used": "verwendet",
|
|
"remaining": "verbleibend",
|
|
"of": "von"
|
|
},
|
|
"invoices": {
|
|
"title": "Rechnungen",
|
|
"subtitle": "Rechnungshistorie und Rechnungen",
|
|
"invoice_number": "Rechnung Nr.",
|
|
"date": "Datum",
|
|
"due_date": "Fälligkeitsdatum",
|
|
"amount": "Betrag",
|
|
"status": "Status",
|
|
"download": "PDF herunterladen",
|
|
"view_online": "Online ansehen",
|
|
"statuses": {
|
|
"paid": "Bezahlt",
|
|
"open": "Offen",
|
|
"void": "Storniert",
|
|
"uncollectible": "Uneinbringlich",
|
|
"draft": "Entwurf"
|
|
}
|
|
},
|
|
"payment": {
|
|
"title": "Zahlung",
|
|
"method": "Zahlungsmethode",
|
|
"add_card": "Karte hinzufügen",
|
|
"update_card": "Karte aktualisieren",
|
|
"no_method": "Keine Zahlungsmethode hinterlegt",
|
|
"card_ending": "Karte endet auf",
|
|
"expires": "Gültig bis"
|
|
},
|
|
"upgrade": {
|
|
"title": "Upgrade",
|
|
"compare": "Pläne vergleichen",
|
|
"select": "Plan auswählen",
|
|
"current": "Aktueller Plan",
|
|
"recommended": "Empfohlen"
|
|
},
|
|
"messages": {
|
|
"subscription_updated": "Abonnement erfolgreich aktualisiert",
|
|
"tier_created": "Stufe erfolgreich erstellt",
|
|
"tier_updated": "Stufe erfolgreich aktualisiert",
|
|
"tier_deactivated": "Stufe deaktiviert",
|
|
"payment_method_updated": "Zahlungsmethode aktualisiert",
|
|
"subscription_cancelled": "Abonnement gekündigt",
|
|
"error_loading": "Fehler beim Laden der Abrechnungsinformationen",
|
|
"error_updating": "Fehler beim Aktualisieren des Abonnements",
|
|
"failed_to_load_billing_data": "Failed to load billing data",
|
|
"failed_to_create_checkout_session": "Failed to create checkout session",
|
|
"failed_to_open_payment_portal": "Failed to open payment portal",
|
|
"subscription_cancelled_you_have_access_u": "Subscription cancelled. You have access until the end of your billing period.",
|
|
"failed_to_cancel_subscription": "Failed to cancel subscription",
|
|
"subscription_reactivated": "Subscription reactivated!",
|
|
"failed_to_reactivate_subscription": "Failed to reactivate subscription",
|
|
"failed_to_purchase_addon": "Failed to purchase add-on",
|
|
"addon_cancelled_successfully": "Add-on cancelled successfully",
|
|
"failed_to_cancel_addon": "Failed to cancel add-on"
|
|
},
|
|
"limits": {
|
|
"orders_exceeded": "Monatliches Bestelllimit erreicht. Upgrade für mehr.",
|
|
"products_exceeded": "Produktlimit erreicht. Upgrade für mehr.",
|
|
"team_exceeded": "Teammitgliederlimit erreicht. Upgrade für mehr."
|
|
}
|
|
}
|