mirror of
https://codeberg.org/PostERG/xamxam.git
synced 2026-06-25 16:19:19 +02:00
- Hardcode source code URL and credits in about template, remove from DB/admin interface; only contacts remains editable - Merge apropos editables into one À propos section, remove charte, add editable source code URL
109 lines
4.3 KiB
PHP
109 lines
4.3 KiB
PHP
<?php
|
|
/**
|
|
* Render a comma-separated list of entries with links.
|
|
* Entries joined with comma, last two joined with " & ".
|
|
*/
|
|
function renderEntries(array $entries): string {
|
|
if (empty($entries)) return '';
|
|
$parts = [];
|
|
foreach ($entries as $e) {
|
|
$text = htmlspecialchars($e['text'] ?? '');
|
|
$url = $e['url'] ?? '';
|
|
if (!empty($url)) {
|
|
$parts[] = '<span class="apropos-entry"><a href="' . htmlspecialchars($url) . '" target="_blank" rel="noopener">' . $text . '</a></span>';
|
|
} else {
|
|
$parts[] = '<span class="apropos-entry">' . $text . '</span>';
|
|
}
|
|
}
|
|
$count = count($parts);
|
|
if ($count === 1) return $parts[0];
|
|
$prefix = implode(', ', array_slice($parts, 0, $count - 2));
|
|
$suffix = implode(' & ', array_slice($parts, -2));
|
|
return $prefix !== '' ? $prefix . ', ' . $suffix : $suffix;
|
|
}
|
|
?>
|
|
<main class="apropos-main" id="main-content">
|
|
<div class="apropos-layout">
|
|
|
|
<!-- LEFT: sticky table of contents -->
|
|
<nav class="apropos-toc" aria-label="Sections de la page">
|
|
<p class="apropos-toc-label">Parties</p>
|
|
<ul>
|
|
<li><a href="#apropos-intro">À propos</a></li>
|
|
<?php if (!empty($contacts)): ?>
|
|
<li><a href="#apropos-contacts">Contacts</a></li>
|
|
<?php endif; ?>
|
|
<li><a href="#apropos-credits">Crédits</a></li>
|
|
</ul>
|
|
<div class="apropos-toc-erg">
|
|
<a href="https://erg.be" target="_blank" rel="noopener">
|
|
Site de l'erg ↗
|
|
</a>
|
|
</div>
|
|
<div class="apropos-toc-source">
|
|
<a href="https://git.erg.school/PostERG/xamxam" target="_blank" rel="noopener">
|
|
Code source ↗
|
|
</a>
|
|
</div>
|
|
</nav>
|
|
|
|
<!-- MIDDLE: main prose + sections -->
|
|
<div class="apropos-content">
|
|
|
|
<!-- Intro text from DB -->
|
|
<section class="apropos-section" id="apropos-intro">
|
|
<div class="prose">
|
|
<?= $aboutHtml ?>
|
|
</div>
|
|
</section>
|
|
|
|
<?php if (!empty($contacts)): ?>
|
|
<!-- Contacts section -->
|
|
<section class="apropos-section" id="apropos-contacts">
|
|
<h2 class="apropos-section-title">Contacts</h2>
|
|
<div class="apropos-contacts-grid">
|
|
<?php foreach ($contacts as $group): ?>
|
|
<address class="apropos-contact-card">
|
|
<?= renderEntries($group['entries'] ?? []) ?>
|
|
<?php if (!empty($group['role'])): ?>
|
|
<span><?= htmlspecialchars($group['role']) ?></span>
|
|
<?php endif; ?>
|
|
<?php
|
|
$emails = array_filter(array_column($group['entries'] ?? [], 'email'), fn($e) => !empty($e));
|
|
foreach ($emails as $email):
|
|
?>
|
|
<a href="mailto:<?= htmlspecialchars($email) ?>"><?= htmlspecialchars($email) ?></a>
|
|
<?php endforeach; ?>
|
|
</address>
|
|
<?php endforeach; ?>
|
|
</div>
|
|
</section>
|
|
<?php endif; ?>
|
|
|
|
<!-- Credits section (hardcoded) -->
|
|
<section class="apropos-section" id="apropos-credits">
|
|
<h2 class="apropos-section-title">Crédits</h2>
|
|
<dl class="apropos-credits-list">
|
|
<div class="apropos-credit-row">
|
|
<dt>Design & développement</dt>
|
|
<dd>
|
|
<span class="apropos-entry">Olivia Marly</span>,
|
|
<span class="apropos-entry">Théophile Gerveau-Mercie</span> &
|
|
<span class="apropos-entry">Théo Hennequin</span>
|
|
</dd>
|
|
</div>
|
|
<div class="apropos-credit-row">
|
|
<dt>Typographies</dt>
|
|
<dd>
|
|
<span class="apropos-entry">Ductus (Amélie Dumont)</span> &
|
|
<span class="apropos-entry">BBB DM Sans</span>
|
|
</dd>
|
|
</div>
|
|
</dl>
|
|
</section>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
</main>
|