Files
crm_ecosplay/templates/emails/client_warning_reset.html.twig

31 lines
1.6 KiB
Twig
Raw Normal View History

feat: systeme complet echeancier SEPA, E-Flex, attestations, avertissements clients Echeancier - Webhooks DocuSeal: - Webhook form.completed: telecharge PDF signe + audit, state SIGNED, prepare SEPA, notifie client + admin - Webhook form.declined: state CANCELLED, notifie client + admin - Reference EC_ECH_XXXXX affichee dans PDF, emails, pages client, admin - Attestation fin de paiement auto via DocuSeal au completion Echeancier - SEPA Direct Debit (remplace Subscriptions): - Page /echeancier/setup-payment/{id}: formulaire IBAN Stripe Elements + mandat SEPA - Confirmation SetupIntent -> stocke PaymentMethod -> state ACTIVE - Commande cron app:echeancier:process-payments: preleve les echeances dues via PaymentIntent off_session - Webhooks payment_intent.succeeded/failed: met a jour EcheancierLine, notifie client - Regularisation CB via Stripe Checkout en cas d'echec prelevement - Bouton "Forcer prelevement" par echeance dans admin - Infos SEPA stockees (last4, bank_code, country) + affichees admin - Page setup_payment_done quand SEPA deja configure - Annulation auto apres 2 rejets + sync paiements vers Advert lie Echeancier - Lien Advert: - Champ advert (ManyToOne nullable) sur Echeancier - Select "Avis lie" dans formulaire creation - AdvertPayment cree a chaque echeance payee - Advert passe en accepted quand echeancier completed Comptabilite: - Export echeanciers CSV/JSON/PDF/PDF signe dans /admin/comptabilite - Colonnes: reference, client, creance, majoration, total, paye, restant, Stripe PI, avis lie Stats: - Case "Total impaye global" = factures impayees + echeances non payees - Tableau echeanciers en cours avec restant du Confiance client: - Statut Confiant/Attention/Danger calcule dynamiquement - Badge en haut a droite de la fiche client - Integre warningLevel (1st=Attention, 2nd=Attention, last=Danger) - Creation echeancier bloquee si Danger (template + controller) Avertissements client (tab Controle, ROLE_ROOT): - 3 niveaux: 1st, 2nd (procedure suspension preparee), last (48h) - Motifs cochables: impayes, irrespect, hors horaires, services gratuits - PDF signe DocuSeal pour chaque avertissement (ClientWarningPdf) - PDF levee avertissement signe (ClientWarningResetPdf) - Webhooks DocuSeal client_warning + client_warning_reset - Barre progression 4 etapes dans admin - Mentions legales: huis clos, contestation direction@e-cosplay.fr Cloture compte: - Bouton "Envoyer notification de cloture" apres dernier avertissement - PDF signe DocuSeal (ClientClosurePdf): suppression 24h, recouvrement, commissaire justice, forces ordre - Bouton "Suspendre le compte" (state suspended) - Webhook DocuSeal client_closure: envoie PDF signe a client + admin + direction Factures: - Auto-generation PDF si absent lors de l'envoi - Bouton "Envoyer" visible meme sans PDF pour factures payees E-Flex (financement services): - Entites EFlex + EFlexLine (reference E_FLEX_XXXXX) - Methodes: SEPA, CB (Stripe Checkout), virement manuel - PDF contrat avec 2 signatures DocuSeal (Company + Client) - Controller admin CRUD + force payment + paiement manuel - Pages client: verify, process, sign, signed, setup SEPA, paiement CB - Webhook DocuSeal eflex: telecharge PDFs, prepare Stripe, notifie - Webhooks Stripe payment_intent: gestion paiements E-Flex - Cron traite aussi les E-Flex SEPA dans process-payments - Tab E-Flex dans fiche client avec liste + modal creation - Emails: signature, signed, verify_code, echeance_payee, echeance_echec Attestations custom (ROLE_ROOT): - Entite AttestationCustom avec items JSON + HMAC SHA-256 - Repeater dynamique pour ajouter elements a attester - PDF avec phrase officielle "Je soussigne(e)..." + QR code verification - Signature manuelle dans DocuSeal (redirection) - Webhook attestation_custom: telecharge PDF signe + audit - Page publique /attestation/verify/{id}/{hmac} avec validation HMAC - Lien dans sidebar Super Admin Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-09 07:45:22 +02:00
{% extends 'email/base.html.twig' %}
{% block content %}
<table width="600" cellpadding="0" cellspacing="0" style="margin: 0 auto;">
<tr>
<td style="padding: 32px;">
{% set greeting = customer.raisonSociale ? 'Chez ' ~ customer.raisonSociale : 'Bonjour ' ~ customer.firstName %}
<h1 style="font-family: Arial, Helvetica, sans-serif; font-size: 22px; font-weight: 700; color: #111827; margin: 0 0 16px;">{{ greeting }},</h1>
<div style="background: #f0fdf4; border-left: 4px solid #16a34a; padding: 16px; margin: 0 0 20px;">
<p style="font-family: Arial, Helvetica, sans-serif; font-size: 14px; font-weight: 700; color: #166534; margin: 0;">
Situation regularisee
</p>
</div>
<p style="font-family: Arial, Helvetica, sans-serif; font-size: 14px; color: #374151; line-height: 22px; margin: 0 0 16px;">
Nous vous confirmons que votre situation a ete regularisee. Les avertissements precedemment emis ont ete leves.
</p>
<p style="font-family: Arial, Helvetica, sans-serif; font-size: 14px; color: #374151; line-height: 22px; margin: 0 0 16px;">
Vos services restent actifs et votre compte est en regle. Nous vous remercions pour votre regularisation.
</p>
<p style="font-family: Arial, Helvetica, sans-serif; font-size: 12px; color: #9ca3af; margin: 20px 0 0;">
Pour toute question : <a href="mailto:contact@e-cosplay.fr" style="color: #fabf04; font-weight: 700;">contact@e-cosplay.fr</a>
</p>
</td>
</tr>
</table>
{% endblock %}