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.3 KiB
PHP
41 lines
1.3 KiB
PHP
<?php
|
|
|
|
return [
|
|
'pattern' => 'request-optimization-appointment.json',
|
|
'method' => 'POST',
|
|
'action' => function () {
|
|
$json = file_get_contents('php://input');
|
|
$data = json_decode($json);
|
|
|
|
$user = kirby()->user();
|
|
$project = page($data->projectUri);
|
|
|
|
$date = new DateTime();
|
|
$formattedDate = $date->format(DateTime::ISO8601);
|
|
|
|
try {
|
|
$project->update([
|
|
"hasOptimizationRequest" => "true",
|
|
"optimizationRequestDetails" => esc("De la part de " . $user->name() . " (" . $user->email() . ") : \n\n" . "Objet : " . $data->subject . "\n" . $data->details),
|
|
// Métadonnées pour le système de notifications dérivées
|
|
"optimizationAuthor" => (string) $user->uuid(),
|
|
"optimizationAuthorName" => (string) $user->name(),
|
|
"optimizationAuthorEmail" => (string) $user->email(),
|
|
"optimizationDate" => $formattedDate,
|
|
"optimizationReadby" => [],
|
|
]);
|
|
|
|
// Note: Les notifications sont maintenant dérivées.
|
|
// Plus besoin d'appeler createNotification().
|
|
|
|
return [
|
|
"status" => "success",
|
|
];
|
|
} catch (\Throwable $th) {
|
|
return [
|
|
"status" => "error",
|
|
"message" => "Can't update project " . $project->title()->value() . ". " . $th->getMessage() . " in " . $th->getFile() . " line " . $th->getLine()
|
|
];
|
|
}
|
|
}
|
|
];
|