espace-paie-odentas/app/(app)/staff/avenants/[id]/page.tsx
odentas 5b72941777 feat: Système complet de gestion des avenants avec signatures électroniques
 Nouvelles fonctionnalités
- Page de gestion des avenants (/staff/avenants)
- Page de détail d'un avenant (/staff/avenants/[id])
- Création d'avenants (objet, durée, rémunération)
- Génération automatique de PDF d'avenant
- Signature électronique via DocuSeal (employeur puis salarié)
- Changement manuel du statut d'un avenant
- Suppression d'avenants

🔧 Routes API
- POST /api/staff/amendments/create - Créer un avenant
- POST /api/staff/amendments/generate-pdf - Générer le PDF
- POST /api/staff/amendments/[id]/send-signature - Envoyer en signature
- POST /api/staff/amendments/[id]/change-status - Changer le statut
- POST /api/webhooks/docuseal-amendment - Webhook après signature employeur
- GET /api/signatures-electroniques/avenants - Liste des avenants en signature

📧 Système email universel v2
- Migration vers le système universel v2 pour les emails d'avenants
- Template 'signature-request-employee-amendment' pour salariés
- Insertion automatique dans DynamoDB pour la Lambda
- Mise à jour automatique du statut dans Supabase

🗄️ Base de données
- Table 'avenants' avec tous les champs (objet, durée, rémunération)
- Colonnes de notification (last_employer_notification_at, last_employee_notification_at)
- Liaison avec cddu_contracts

🎨 Composants
- AvenantDetailPageClient - Détail complet d'un avenant
- ChangeStatusModal - Changement de statut manuel
- SendSignatureModal - Envoi en signature
- DeleteAvenantModal - Suppression avec confirmation
- AvenantSuccessModal - Confirmation de création

📚 Documentation
- AVENANT_EMAIL_SYSTEM_MIGRATION.md - Guide complet de migration

🐛 Corrections
- Fix parsing défensif dans Lambda AWS
- Fix récupération des données depuis DynamoDB
- Fix statut MFA !== 'verified' au lieu de === 'unverified'
2025-10-23 15:30:11 +02:00

68 lines
1.5 KiB
TypeScript

import { createSbServer } from "@/lib/supabaseServer";
import { redirect, notFound } from "next/navigation";
import AvenantDetailPageClient from "@/components/staff/avenants/AvenantDetailPageClient";
export const dynamic = "force-dynamic";
export default async function AvenantDetailPage({
params,
}: {
params: Promise<{ id: string }>;
}) {
const { id } = await params;
const sb = createSbServer();
const { data: { user } } = await sb.auth.getUser();
if (!user) {
redirect("/login");
}
const { data: me } = await sb
.from("staff_users")
.select("is_staff")
.eq("user_id", user.id)
.maybeSingle();
const isStaff = !!me?.is_staff;
if (!isStaff) {
redirect("/dashboard");
}
// Récupérer l'avenant avec les informations du contrat
const { data: avenant, error } = await sb
.from("avenants")
.select(`
*,
cddu_contracts (
*,
organizations (
id,
name,
organization_details (
email_signature
)
),
salaries (
prenom,
nom,
adresse_mail
)
)
`)
.eq("id", id)
.single();
console.log("Recherche avenant ID:", id);
console.log("Résultat:", { avenant, error });
if (error || !avenant) {
console.error("Erreur ou avenant non trouvé:", error);
notFound();
}
return (
<main className="p-6">
<AvenantDetailPageClient avenant={avenant} />
</main>
);
}