mirror of
https://codeberg.org/PostERG/xamxam.git
synced 2026-05-07 03:29:19 +02:00
SQLite performance (Database::__construct): - PRAGMA journal_mode = WAL: eliminates full-DB read locks on write, safe for concurrent PHP-FPM workers - PRAGMA synchronous = NORMAL: durable on commit without full fsync per write - PRAGMA cache_size = -8000: ~8 MB page cache per connection Accessibility foundation (WCAG 2.1 AA): - common.css: add .sr-only utility, .skip-link (hidden until focused), global :focus-visible (2px purple outline, 2px offset), prefers-reduced-motion guard; remove bare outline:none from .site-search__input - admin.css: same :focus-visible, skip-link, and motion guard scoped to admin purple; remove outline:none from .admin-input/.admin-select/ .admin-textarea and .admin-filters select (both had :focus border rules already, so focus is still visually communicated) - search.css: remove outline:none from .search-filter-select (already has :focus border-color rule) - All 5 public pages (index, search, tfe, apropos, licence): add <a href="#main-content" class="skip-link"> as first child of <body>; add id="main-content" to <main> - templates/admin/head.php: same skip link; aria-label="Navigation admin" on <nav>; id="main-content" on all 10 admin <main> elements All 4 test suites pass (unit, integration, security, rate-limit).
112 lines
4.5 KiB
PHP
112 lines
4.5 KiB
PHP
<?php
|
||
require_once __DIR__ . '/../config/bootstrap.php';
|
||
require_once APP_ROOT . '/src/Database.php';
|
||
require_once APP_ROOT . '/src/Parsedown.php';
|
||
|
||
$currentNav = 'apropos';
|
||
|
||
// Fallback static content used when DB content is the placeholder
|
||
define('APROPOS_STATIC_CONTENT', "Ce site POSTERG a été créé pour répertorier et valoriser les mémoires de l'erg – École de Recherches Graphique de Bruxelles.\n\nL'objectif est à la fois d'offrir une vitrine aux projets des anciens étudiantes et de mettre en lumière la diversité des disciplines et des parcours qui façonnent l'histoire de l'école à travers les âges, depuis près de 100 ans.");
|
||
|
||
try {
|
||
$db = Database::getInstance();
|
||
$aboutPage = $db->getPage('about');
|
||
$rawContent = $aboutPage ? $aboutPage['content'] : '';
|
||
// Use static fallback if content is placeholder
|
||
if (empty(trim($rawContent)) || trim($rawContent) === 'Contenu à venir') {
|
||
$rawContent = APROPOS_STATIC_CONTENT;
|
||
}
|
||
} catch (Exception $e) {
|
||
error_log("Error loading about page: " . $e->getMessage());
|
||
$rawContent = APROPOS_STATIC_CONTENT;
|
||
}
|
||
|
||
$pd = new Parsedown();
|
||
$pd->setSafeMode(true);
|
||
$aboutHtml = $pd->text($rawContent);
|
||
?>
|
||
<!DOCTYPE html>
|
||
<html lang="fr">
|
||
<head>
|
||
<meta charset="UTF-8">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||
<title>À Propos – Posterg</title>
|
||
<link rel="icon" type="image/svg+xml" href="/assets/admin_favicon.svg">
|
||
<link rel="stylesheet" href="assets/modern-normalize.min.css">
|
||
<link rel="stylesheet" href="assets/common.css">
|
||
<link rel="stylesheet" href="assets/apropos.css">
|
||
<?php if (php_sapi_name() === 'cli-server'): ?>
|
||
<script>
|
||
(function poll(){
|
||
fetch('/live-reload.php').then(r=>r.json()).then(d=>{
|
||
if(d.changed) location.reload(); else setTimeout(poll,1000);
|
||
}).catch(()=>setTimeout(poll,2000));
|
||
})();
|
||
</script>
|
||
<?php endif; ?>
|
||
</head>
|
||
<body class="apropos-body">
|
||
<a href="#main-content" class="skip-link">Aller au contenu principal</a>
|
||
|
||
<?php include APP_ROOT . '/templates/nav.php'; ?>
|
||
<?php include APP_ROOT . '/templates/search-bar.php'; ?>
|
||
|
||
<main class="apropos-main" id="main-content">
|
||
<div class="apropos-layout">
|
||
|
||
<!-- LEFT: main text (from DB, Markdown-rendered) -->
|
||
<div class="apropos-left">
|
||
<div class="apropos-description apropos-page-content">
|
||
<?= $aboutHtml ?>
|
||
</div>
|
||
</div>
|
||
|
||
<!-- RIGHT: links, contacts, credits -->
|
||
<div class="apropos-right">
|
||
|
||
<div>
|
||
<h2 class="apropos-section-title">
|
||
<a href="https://erg.be" target="_blank" rel="noopener">Site de l'erg</a>
|
||
</h2>
|
||
</div>
|
||
|
||
<div>
|
||
<h2 class="apropos-section-title">Contacts</h2>
|
||
|
||
<div class="apropos-contact">
|
||
<span class="apropos-contact-name">Laurent Leprince</span>
|
||
<span class="apropos-contact-role">Bibliothèque d'architecture, d'ingénierie architecturale, d'urbanisme (BAIU) :</span>
|
||
<span class="apropos-contact-email">laurent.leprince@uclouvain.be</span>
|
||
</div>
|
||
|
||
<div class="apropos-contact">
|
||
<span class="apropos-contact-name">Xavier Gorgol</span>
|
||
<span class="apropos-contact-role">Responsable des mémoires de l'ERG :</span>
|
||
<span class="apropos-contact-email">xavier.gorgol@erg.be</span>
|
||
</div>
|
||
|
||
<div class="apropos-contact">
|
||
<span class="apropos-contact-name">Brigitte Ledune</span>
|
||
<span class="apropos-contact-role">Cours de suivi de mémoire :</span>
|
||
<span class="apropos-contact-email">brigitte.ledune@erg.be</span>
|
||
</div>
|
||
</div>
|
||
|
||
<div>
|
||
<h2 class="apropos-section-title">Crédits</h2>
|
||
<p class="apropos-credits-text">
|
||
Design & développement : Olivia Marly, Théophile Gerveau-Mercie & Théo Hennequin
|
||
</p>
|
||
<p class="apropos-credits-text">
|
||
Typographies : Ductus (Amélie Dumont) & BBB DM Sans
|
||
</p>
|
||
</div>
|
||
|
||
</div>
|
||
|
||
</div>
|
||
</main>
|
||
|
||
</body>
|
||
</html>
|