Feature: Partner-Profile Backend + Pro-Zugang für Partner
Die Partner-Showcase-Seite (#partner) und der Profil-Editor (#partner-profil) existierten seit v1102 nur als Frontend — /api/partners/public und /api/partner/my-profile gab es nie (vermutlich Worktree-Merge-Verlust). Backend neu: - partner_profiles-Tabelle (user_id PK, ON DELETE CASCADE → DSGVO-Delete greift) - GET/PUT /partner/my-profile (Texte, Website-Normalisierung, @-Instagram) - Logo-Upload (≤5 MB → WebP 512px, altes Logo wird geräumt) - Foto/Video-Upload (max 6, 200-MB-Budget, HEIC→JPEG, MOV→MP4 via ffmpeg, Bilder→WebP 1600px) + Lösch-Endpoint - Submit-Workflow (approved 0/1/-1) + Admin-Mail (best effort) - GET /partners/public (nur freigegebene, JOIN users für Name/Avatar) - Admin: GET /admin/partner/profiles + POST .../review Pro für Partner: has_pro_access() + App._hasPro() prüfen jetzt is_partner — Multiplikatoren bekommen Pro gratis (mehrere Hunde, KI-Trainer etc.). UI: Admin-Partner-Tab mit Freigabe-Sektion (offen-Badge, ✓/✗), Settings zeigt Partnern eine Karte mit Link zum Profil-Editor. Tests: tests/test_partner_profile.py — 5 Smoke-Tests (403, Voll-Flow inkl. Freigabe/Ablehnung, Pflicht-Anzeigename, Logo+Foto-Upload, Pro-Zugang). Suite: 44 passed.
This commit is contained in:
parent
178aef7fb0
commit
ce8aa2b699
11 changed files with 557 additions and 19 deletions
|
|
@ -86,14 +86,14 @@
|
|||
<title>Ban Yaro</title>
|
||||
|
||||
<!-- Theme + theme-color Statusleiste vor CSS setzen -->
|
||||
<script src="/js/boot-early.js?v=1252"></script>
|
||||
<script src="/js/boot-early.js?v=1253"></script>
|
||||
|
||||
<!-- CSS: Reihenfolge ist wichtig — ?v= zwingt Browser zur Neuladung -->
|
||||
<link rel="stylesheet" href="/css/design-system.css?v=1252">
|
||||
<link rel="stylesheet" href="/css/layout.css?v=1252">
|
||||
<link rel="stylesheet" href="/css/components.css?v=1252">
|
||||
<link rel="stylesheet" href="/css/utilities.css?v=1252">
|
||||
<link rel="stylesheet" href="/css/lists.css?v=1252">
|
||||
<link rel="stylesheet" href="/css/design-system.css?v=1253">
|
||||
<link rel="stylesheet" href="/css/layout.css?v=1253">
|
||||
<link rel="stylesheet" href="/css/components.css?v=1253">
|
||||
<link rel="stylesheet" href="/css/utilities.css?v=1253">
|
||||
<link rel="stylesheet" href="/css/lists.css?v=1253">
|
||||
</head>
|
||||
<body>
|
||||
|
||||
|
|
@ -612,11 +612,11 @@
|
|||
<div id="modal-container"></div>
|
||||
|
||||
<!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features -->
|
||||
<script src="/js/api.js?v=1252"></script>
|
||||
<script src="/js/ui.js?v=1252"></script>
|
||||
<script src="/js/app.js?v=1252"></script>
|
||||
<script src="/js/worlds.js?v=1252"></script>
|
||||
<script src="/js/offline-indicator.js?v=1252"></script>
|
||||
<script src="/js/api.js?v=1253"></script>
|
||||
<script src="/js/ui.js?v=1253"></script>
|
||||
<script src="/js/app.js?v=1253"></script>
|
||||
<script src="/js/worlds.js?v=1253"></script>
|
||||
<script src="/js/offline-indicator.js?v=1253"></script>
|
||||
|
||||
<!-- Feature-Seiten werden lazy geladen -->
|
||||
|
||||
|
|
@ -626,7 +626,7 @@
|
|||
|
||||
|
||||
<!-- Boot: Offline-Banner + SW-Registration (extrahiert für CSP) -->
|
||||
<script src="/js/boot.js?v=1252"></script>
|
||||
<script src="/js/boot.js?v=1253"></script>
|
||||
|
||||
|
||||
</body>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue