Ajout de collectLight() pour optimiser le chargement du listing des projets
Problème : projects.json.php causait un dépassement mémoire en collectant toutes les notifications complètes (avec author, location, text, etc.) pour tous les projets. Solution : Nouvelle méthode collectLight() qui ne retourne que les données minimales nécessaires au frontend pour afficher les indicateurs : - id, type, isRead, date - location.project.uri (pour le filtrage) Les détails complets sont toujours chargés dans project.json.php individuel. Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
parent
0250dc1487
commit
0a980603a4
2 changed files with 63 additions and 7 deletions
|
|
@ -57,6 +57,49 @@ class NotificationCollector
|
|||
return $all;
|
||||
}
|
||||
|
||||
/**
|
||||
* Collecte uniquement les données minimales des notifications (version allégée pour listing).
|
||||
* Retourne seulement id, type, isRead, date pour économiser la mémoire.
|
||||
*
|
||||
* @param Page $project Le projet à scanner
|
||||
* @param User $user L'utilisateur courant
|
||||
* @return array Liste triée par date décroissante
|
||||
*/
|
||||
public function collectLight(Page $project, User $user): array
|
||||
{
|
||||
$all = [];
|
||||
|
||||
foreach ($this->providers as $provider) {
|
||||
try {
|
||||
$notifications = $provider->collect($project, $user);
|
||||
// Ne garder que les champs essentiels
|
||||
foreach ($notifications as $notification) {
|
||||
$all[] = [
|
||||
'id' => $notification['id'] ?? null,
|
||||
'type' => $notification['type'] ?? null,
|
||||
'isRead' => $notification['isRead'] ?? false,
|
||||
'date' => $notification['date'] ?? null,
|
||||
// Garder location.project.uri pour le frontend
|
||||
'location' => [
|
||||
'project' => $notification['location']['project'] ?? []
|
||||
]
|
||||
];
|
||||
}
|
||||
} catch (\Throwable $e) {
|
||||
error_log("NotificationCollector: Error in {$provider->getType()}: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
// Trier par date décroissante
|
||||
usort($all, function ($a, $b) {
|
||||
$dateA = strtotime($a['date'] ?? '0');
|
||||
$dateB = strtotime($b['date'] ?? '0');
|
||||
return $dateB - $dateA;
|
||||
});
|
||||
|
||||
return $all;
|
||||
}
|
||||
|
||||
/**
|
||||
* Marque une notification comme lue en déléguant au bon provider.
|
||||
*
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue