<?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>