Remplace le système de notifications stockées par un système de providers qui dérivent les notifications des données existantes (commentaires, réponses, demandes de projet, demandes de rendez-vous, validations de brief). - Ajout du NotificationCollector et de l'interface NotificationProvider - Création de 5 providers : Comment, Reply, ProjectRequest, AppointmentRequest, Content - Métadonnées de notifications stockées directement sur les entités source - Nouvelles routes mark-as-read et mark-all-read - Mise à jour du frontend pour le nouveau système - Route de migration pour les données existantes Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
41 lines
1.2 KiB
PHP
41 lines
1.2 KiB
PHP
<?php
|
|
|
|
return [
|
|
'pattern' => '(:all)validate-brief.json',
|
|
'method' => 'POST',
|
|
'action' => function () {
|
|
$json = file_get_contents('php://input');
|
|
$data = json_decode($json);
|
|
|
|
$page = page($data->briefUri);
|
|
$project = $page->parent();
|
|
$user = kirby()->user();
|
|
|
|
try {
|
|
$timezone = new DateTimeZone('Europe/Paris');
|
|
$dateTime = new DateTime('now', $timezone);
|
|
|
|
$newPage = $page->update([
|
|
'isValidated' => 'true',
|
|
// Métadonnées pour le système de notifications dérivées
|
|
'validatedBy' => (string) $user->uuid(),
|
|
'validatedByName' => (string) $user->name(),
|
|
'validatedByEmail' => (string) $user->email(),
|
|
'validatedAt' => $dateTime->format('Y-m-d\TH:i:sP'),
|
|
'validationReadby' => [],
|
|
]);
|
|
|
|
// Note: Les notifications sont maintenant dérivées.
|
|
// Plus besoin d'appeler createNotification().
|
|
|
|
return [
|
|
"success" => "'" . $project->title()->value() . "' brief validated."
|
|
];
|
|
} catch (\Throwable $th) {
|
|
return [
|
|
"error" => "Can't validate '" . $page->title()->value() . "' brief.",
|
|
'details' => $th->getMessage()
|
|
];
|
|
}
|
|
}
|
|
];
|