<?php require_once '../includes/config.php'; require_once '../includes/auth.php'; require_once '../includes/stories.php'; // Vérification de l'authentification if (!Auth::check()) { header('Location: login.php'); exit; } // Récupération des messages de l'import s'ils existent $success = ''; $error = ''; if (isset($_SESSION['import_result'])) { if (!empty($_SESSION['import_result']['success'])) { $success = $_SESSION['import_result']['success']; } if (!empty($_SESSION['import_result']['error'])) { $error = $_SESSION['import_result']['error']; } unset($_SESSION['import_result']); } $stories = Stories::getAll(); ?> <!DOCTYPE html> <html lang="fr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Import/Export des romans - Administration</title> <?php if (file_exists(__DIR__ . '/../assets/images/site/favicon.png')): ?> <link rel="icon" type="image/png" href="../assets/images/site/favicon.png"> <?php endif; ?> <link rel="stylesheet" href="../assets/css/main.css"> </head> <body> <nav class="admin-nav"> <div class="nav-brand"> <?php $config = Config::load(); if (!empty($config['site']['logo'])): ?> <img src="<?= htmlspecialchars('../' . $config['site']['logo']) ?>" alt="<?= htmlspecialchars($config['site']['name']) ?>"> <?php endif; ?> <span>Administration</span> </div> <div class="nav-menu"> <a href="index.php" class="button tooltip" data-tooltip="Retour"> <i class="fas fa-arrow-left"></i> </a> </div> </nav> <main class="admin-main"> <h1>Import/Export des romans</h1> <?php if ($success): ?> <div class="success-message"><?= htmlspecialchars($success) ?></div> <?php endif; ?> <?php if ($error): ?> <div class="error-message"><?= htmlspecialchars($error) ?></div> <?php endif; ?> <!-- Section Export --> <section class="export-section"> <h2>Exporter des romans</h2> <form id="exportForm" action="api/export-stories.php" method="POST"> <div class="stories-selection"> <?php foreach ($stories as $story): ?> <div class="story-checkbox"> <label> <input type="checkbox" name="stories[]" value="<?= htmlspecialchars($story['id']) ?>"> <?= htmlspecialchars($story['title']) ?> </label> </div> <?php endforeach; ?> </div> <div class="form-actions"> <button type="button" class="button tooltip select-all" data-tooltip="Tout sélectionner"> <i class="fas fa-check-square"></i> <span class="tooltip-text">Tout sélectionner</span> </button> <button type="submit" class="button tooltip" data-tooltip="Exporter"> <i class="fas fa-upload"></i> <span class="tooltip-text">Exporter</span> </button> </div> </form> </section> <!-- Section Import --> <section class="import-section"> <h2>Importer des romans</h2> <form id="importForm" action="api/import-stories.php" method="POST" enctype="multipart/form-data"> <div class="form-group"> <label for="importFile">Sélectionner une archive ZIP</label> <input type="file" id="importFile" name="importFile" accept=".zip" required> </div> <div class="form-group"> <label> <input type="checkbox" name="overwrite" value="1"> Écraser les romans existants </label> </div> <button type="submit" class="button tooltip" data-tooltip="Importer"> <i class="fas fa-download"></i> <span class="tooltip-text">Importer</span> </button> </form> </section> </main> <script> document.addEventListener('DOMContentLoaded', function() { // Gestion de la sélection/désélection de tous les romans const selectAllBtn = document.querySelector('.select-all'); const checkboxes = document.querySelectorAll('input[name="stories[]"]'); selectAllBtn.addEventListener('click', function() { const allChecked = Array.from(checkboxes).every(cb => cb.checked); checkboxes.forEach(cb => cb.checked = !allChecked); // Mise à jour du texte de la tooltip et non du contenu du bouton const tooltipText = this.querySelector('.tooltip-text'); if (tooltipText) { tooltipText.textContent = allChecked ? 'Tout sélectionner' : 'Tout désélectionner'; } // Mise à jour de l'attribut data-tooltip pour que le survol affiche le bon texte this.setAttribute('data-tooltip', allChecked ? 'Tout sélectionner' : 'Tout désélectionner'); }); // Validation du formulaire d'export document.getElementById('exportForm').addEventListener('submit', function(e) { const selected = document.querySelectorAll('input[name="stories[]"]:checked'); if (selected.length === 0) { e.preventDefault(); alert('Veuillez sélectionner au moins un roman à exporter.'); } }); // Validation de l'import document.getElementById('importForm').addEventListener('submit', function(e) { const file = document.getElementById('importFile').files[0]; if (!file) { e.preventDefault(); alert('Veuillez sélectionner un fichier ZIP à importer.'); return; } if (!file.name.toLowerCase().endsWith('.zip')) { e.preventDefault(); alert('Seuls les fichiers ZIP sont acceptés.'); return; } }); }); </script> <style> .export-section, .import-section { background: var(--bg-tertiary); padding: var(--spacing-lg); border-radius: var(--radius-md); margin-bottom: var(--spacing-xl); border: 1px solid var(--border-color); } .stories-selection { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: var(--spacing-md); margin: var(--spacing-lg) 0; } .story-checkbox { padding: var(--spacing-sm); background: var(--bg-secondary); border-radius: var(--radius-sm); } .story-checkbox label { display: flex; align-items: center; gap: var(--spacing-sm); cursor: pointer; } .form-actions { display: flex; gap: var(--spacing-md); margin-top: var(--spacing-lg); } .import-section .form-group { margin-bottom: var(--spacing-md); } </style> <link rel="stylesheet" href="../assets/css/dialog.css"> <script src="../assets/js/dialog.js"></script> </body> </html>