mirror of
https://codeberg.org/PostERG/xamxam.git
synced 2026-06-25 08:09:18 +02:00
* **Unified Format + Fichiers into a single HTMX fragment**
* Introduced `app/public/partage/fichiers-fragment.php` as shared dynamic block returning both format checkboxes and adaptive “Fichiers” fieldset
* Logic adapts inputs based on selected formats:
* no selection / upload formats → standard file inputs
* “Site web” → URL fields only
* “Site web + upload” → file inputs + URL sub-fieldset
* Added admin wrapper: `app/public/admin/fichiers-fragment.php` (gated via `admin_mode=1`)
* Added `app/public/admin/format-website-fragment.php` for edit-mode website URL toggling
* Wired route `/partage/fichiers-fragment` in `app/public/partage/index.php`
* Refactored `form.php` (add/edit partage) to use single `#format-fichiers-block` instead of separate fragments
* Edit mode format checkboxes now target `format-website-fragment.php` → `#edit-website-url-fieldset`
* Added `$hxInclude` support in `checkbox-list.php` for configurable HTMX includes
* **Format system migration + ordering**
* Migration `020_format_types_sort_and_rename.sql`:
* added `sort_order` column to `format_types`
* inserted new format **Image**
* defined ordering: Écriture · Image · Audio · Vidéo · Site web · Performance · Objet éditorial · Installation · Autre
* `Database.php`: format queries now use `ORDER BY sort_order, id`
* `fichiers-fragment.php`:
* uses ordered format list
* resolves Image/Vidéo/Audio by name
* introduces `$hasImage` flag
* preserves `admin_mode` across HTMX requests
* **File constraints and UX updates**
* Enforced **100 MB PDF limit**
* `ThesisCreateController`: `MAX_PDF_SIZE = 100MB` for PDFs only
* `ThesisEditController`: same PDF-specific constraint applied
* Other file types remain capped at 500 MB
* Updated UI hints in `fichiers-fragment.php` and edit form:
* explicitly mention 100 MB PDF limit
* added reference to `bentopdf.com` for compression guidance
* `file-field.php`: added `$hintRaw` to allow HTML rendering in hints
* **Admin authentication fix**
* Fixed missing auth in admin fragments
* Added `require_once AdminAuth.php`
* Replaced direct usage with `AdminAuth::requireLogin()`
* Applied consistent pattern with existing fragment authentication approach
* **Migrations included**
* `019_add_ecriture_format.sql`
* `020_format_types_sort_and_rename.sql`
* **Files affected**
* Controllers: `ThesisCreateController`, `ThesisEditController`
* DB layer: `Database.php`
* Public fragments: `partage/fichiers-fragment.php`, `admin/fichiers-fragment.php`, `admin/format-website-fragment.php`
* Templates: `form.php`, `checkbox-list.php`, `file-field.php`
* Routing: `partage/index.php`
* Misc: `TODO.md`
This consolidates format normalization, HTMX UI simplification, file validation rules, and admin stability fixes into a single coherent system update.
58 lines
2.0 KiB
PHP
58 lines
2.0 KiB
PHP
<?php
|
|
/**
|
|
* format-website-fragment.php (admin)
|
|
*
|
|
* Admin-gated HTMX fragment: returns the Site web URL fieldset for the
|
|
* admin edit form when "Site web" is among the selected format checkboxes.
|
|
* Uses id="edit-website-url-fieldset" to avoid collision with the partage form.
|
|
*/
|
|
require_once __DIR__ . '/../../bootstrap.php';
|
|
require_once __DIR__ . '/../../src/AdminAuth.php';
|
|
App::boot();
|
|
|
|
AdminAuth::requireLogin();
|
|
|
|
$db = Database::getInstance()->getConnection();
|
|
|
|
$stmt = $db->prepare('SELECT id FROM format_types WHERE name = ? LIMIT 1');
|
|
$stmt->execute(['Site web']);
|
|
$websiteFormatId = $stmt->fetchColumn();
|
|
|
|
if (!$websiteFormatId) {
|
|
echo '<fieldset id="edit-website-url-fieldset" style="display:none"></fieldset>';
|
|
exit;
|
|
}
|
|
|
|
$selectedFormats = isset($_POST['formats']) && is_array($_POST['formats'])
|
|
? array_map('intval', $_POST['formats'])
|
|
: [];
|
|
|
|
if (!in_array((int)$websiteFormatId, $selectedFormats, true)) {
|
|
echo '<fieldset id="edit-website-url-fieldset" style="display:none"></fieldset>';
|
|
exit;
|
|
}
|
|
|
|
$websiteUrl = htmlspecialchars($_POST['website_url'] ?? '');
|
|
$websiteLabel = htmlspecialchars($_POST['website_label'] ?? '');
|
|
?>
|
|
<fieldset id="edit-website-url-fieldset">
|
|
<legend>Site web</legend>
|
|
<div class="admin-form-group">
|
|
<label for="website_url">URL du site :</label>
|
|
<div class="admin-file-input">
|
|
<input type="url" id="website_url" name="website_url"
|
|
value="<?= $websiteUrl ?>"
|
|
placeholder="https://mon-tfe.erg.be">
|
|
<small>Si le TFE est un site web, entrez son URL ici. Il sera affiché comme un site embarqué sur la page du TFE.</small>
|
|
</div>
|
|
</div>
|
|
<div class="admin-form-group">
|
|
<label for="website_label">Légende :</label>
|
|
<input type="text" id="website_label" name="website_label"
|
|
value="<?= $websiteLabel ?>"
|
|
placeholder="Description du site (optionnel)"
|
|
class="admin-file-label-input"
|
|
style="max-width:400px;">
|
|
</div>
|
|
</fieldset>
|