nettoyage du 12 décembre
This commit is contained in:
@@ -87,7 +87,7 @@
|
||||
</header>
|
||||
<main>
|
||||
<div class="ajouter">
|
||||
<a href="#" class="btn btn-primary btn-sm my-2">Ajouter une citation</a>
|
||||
<a href="#" class="btn btn-primary ">Ajouter une citation</a>
|
||||
</div>
|
||||
<section class="chiens my-4">
|
||||
<h2 class="fs-4">Citations chiens</h2>
|
||||
|
||||
@@ -1,88 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Liste des résultats avant/après</title>
|
||||
<link href="../../node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||
<link rel="stylesheet" href="../../node_modules/bs-icon/icons.css">
|
||||
<link rel="stylesheet" href="../../css/style.css">
|
||||
<link rel="stylesheet" href="../../css/avant_apres.css">
|
||||
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div id="header-placeholder"></div>
|
||||
|
||||
|
||||
<main class="my-5 fs-6">
|
||||
<div class="container">
|
||||
<header>
|
||||
<h1 class="title fs-2 my-4">Liste des résultats avant/après</h1>
|
||||
<!-- Message succès -->
|
||||
<div id="succesDeleteMsg" class="alert alert-success d-none">
|
||||
Résultat supprimé avec succès !
|
||||
</div>
|
||||
</header>
|
||||
|
||||
<div class="section">
|
||||
|
||||
<div class="d-flex justify-content-start mb-4">
|
||||
<a href="../html/ajouter_avant_apres.html" class="btn btn-primary">
|
||||
Ajouter un résultat
|
||||
</a>
|
||||
</div>
|
||||
|
||||
<!-- Table responsive -->
|
||||
<div class="table-responsive">
|
||||
<table class="table table-striped table-hover align-middle mb-0">
|
||||
<thead class="table-dark">
|
||||
<tr>
|
||||
<th>Titre du résultat</th>
|
||||
<th class="text-end">Actions</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody id="prestationTableBody">
|
||||
<!-- JS -->
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!--- modale de suppression-->
|
||||
<div class="modal fade" id="deleteModal" tabindex="-1" role="dialog" aria-hidden="true">
|
||||
<div class="modal-dialog">
|
||||
<div class="modal-content">
|
||||
|
||||
<div class="modal-header">
|
||||
<h2 class="modal-title" id="deleteModalLabel">Confirmer la suppression</h2>
|
||||
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Fermer"></button>
|
||||
</div>
|
||||
|
||||
<div class="modal-body">
|
||||
Voulez-vous vraiment supprimer ce résultat avant/après ?
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Annuler</button>
|
||||
<button type="button" class="btn btn-danger" id="confirmDeleteBtn">Supprimer</button>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</main>
|
||||
|
||||
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||
<script src="../js/liste_avant_apres.js"></script>
|
||||
<script src="../../header-composant.js"></script>
|
||||
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
@@ -1,59 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Liste des prestations</title>
|
||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
||||
|
||||
|
||||
<style>
|
||||
body {
|
||||
background: #f4f6f9;
|
||||
padding: 30px;
|
||||
}
|
||||
.container {
|
||||
margin-top: 100px;
|
||||
}
|
||||
.action-btns button,
|
||||
.action-btns a {
|
||||
margin-right: 100px;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div class="container">
|
||||
<h2 class="mb-5 text-center">Liste des prestations</h2>
|
||||
|
||||
<!--Message succès-->
|
||||
<div id="succesDeleteMsg" class="alert alert-success d-none">Prestation supprimée avec succès !</div>
|
||||
|
||||
<div class="d-flex justify-content-end mb-4">
|
||||
<a href="../ajouter_prestation/ajouter_prestation.html" class="btn btn-primary">Ajouter une prestation</a>
|
||||
</div>
|
||||
|
||||
|
||||
<table class="table table-striped table-hover align-middle">
|
||||
<thead class="table-dark">
|
||||
<tr>
|
||||
<th>Titre</th>
|
||||
<th>Type</th>
|
||||
<th>Description</th>
|
||||
<th>Tarif</th>
|
||||
<th class="text-center">Actions</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody id="prestationTableBody">
|
||||
<!--Rempli en JS-->
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<script src="../../prestations/liste_prestation/liste_prestation.js"></script>
|
||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
||||
|
||||
|
||||
</body>
|
||||
</html>
|
||||
@@ -1,135 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Liste des slides</title>
|
||||
<link href="../../node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||
<link rel="stylesheet" href="../../node_modules/bs-icon/icons.css">
|
||||
<link rel="stylesheet" href="../../css/style.css">
|
||||
|
||||
<style>
|
||||
body {
|
||||
background: #f4f6f9;
|
||||
padding: 40px;
|
||||
}
|
||||
|
||||
.container {
|
||||
max-width: 900px;
|
||||
}
|
||||
|
||||
.miniature {
|
||||
width: 90px;
|
||||
height: 60px;
|
||||
object-fit: cover;
|
||||
border-radius: 5px;
|
||||
}
|
||||
|
||||
.action-buttons button,
|
||||
.action-buttons a {
|
||||
margin-right: 8px;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<header>
|
||||
<nav class="navbar navbar-expand-xxl bg-body-tertiary">
|
||||
<div class="container-fluid align-items-center">
|
||||
<a class="navbar-brand" href="#">L'Il'eau chiens - Admin</a>
|
||||
|
||||
|
||||
|
||||
<button class="navbar-toggler" type="button" data-bs-toggle="collapse"
|
||||
data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent"
|
||||
aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
||||
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
||||
<li class="nav-item">
|
||||
<a class="nav-link active left-label" aria-current="page" href="#">Blog</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link left-label" href="#">Boutique</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link left-label" href="#">Prestations</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link left-label" href="#">FAQ</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link left-label" href="#">Fiche de renseignements</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link left-label" href="#">Partenaires</a>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
|
||||
<ul class="navbar-nav ms-auto mb-2 mb-lg-0">
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="#"><i class="bi bi-megaphone me-1"></i> Message d'actu</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="#"><i class="bi bi-box-arrow-up-right me-1"></i> Voir le site</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link" href="#"><i class="bi bi-gear me-1"></i> Configuration</a>
|
||||
</li>
|
||||
<li class="nav-item dropdown">
|
||||
<a class="nav-link dropdown-toggle" href="#" id="userMenu" role="button" data-bs-toggle="dropdown" aria-expanded="false">
|
||||
<i class="bi bi-person-circle me-1"></i> <span id="userFirstName">Prénom</span>
|
||||
</a>
|
||||
<ul class="dropdown-menu dropdown-menu-end" aria-labelledby="userMenu">
|
||||
<li><a class="dropdown-item" href="#">Profil</a></li>
|
||||
<li><hr class="dropdown-divider"></li>
|
||||
<li><a class="dropdown-item" href="#">Sortir</a></li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
</header>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="container">
|
||||
|
||||
<h2 class="text-center mb-4">Slider – Liste des images</h2>
|
||||
|
||||
<!-- Message succès (suppression / ordre) -->
|
||||
<div id="successMsg" class="alert alert-success d-none"></div>
|
||||
|
||||
<!-- Bouton ajouter -->
|
||||
<div class="d-flex justify-content-start mb-4">
|
||||
<a href="../html/ajouter_slider.html" class="btn btn-primary">Ajouter une image au slider</a>
|
||||
</div>
|
||||
|
||||
<table class="table table-striped table-hover align-middle">
|
||||
<thead class="table-dark">
|
||||
<tr>
|
||||
<th>Image</th>
|
||||
<th>Texte ALT</th>
|
||||
<th>Titre</th>
|
||||
<th>Ordre</th>
|
||||
<th class="text-center">Actions</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody id="sliderTableBody">
|
||||
<!-- rempli en JS -->
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<script src="../js/liste_slider.js"></script>
|
||||
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
@@ -1,64 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="fr">
|
||||
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Voir le résultat avant/après</title>
|
||||
<link href="../../node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||
<link rel="stylesheet" href="../../node_modules/bs-icon/icons.css">
|
||||
<link rel="stylesheet" href="../../css/style.css">
|
||||
<link rel="stylesheet" href="../../css/avant_apres.css">
|
||||
<link rel="stylesheet" href="../../header-composant.html">
|
||||
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="container">
|
||||
|
||||
<h1 class="mb-4 text-center">Détails du résultat en images (Avant / Après)</h1>
|
||||
|
||||
<!-- Message erreur -->
|
||||
<div id="errorMsg" class="alert alert-danger d-none">
|
||||
Impossible d'afficher ce résultat.
|
||||
</div>
|
||||
|
||||
<div id="detailsSection" class="mt-3">
|
||||
|
||||
<h2 id="pairTitle" class="text-center mb-4" aria-live="polite">Chargement...</h2>
|
||||
|
||||
|
||||
<!-- AVANT / APRÈS : empilés en mobile, côte à côte en md+ -->
|
||||
<div class="row justify-content-center align-items-start mb-4 g-4">
|
||||
|
||||
<div class="col-12 col-md-6 text-center">
|
||||
<p class="fw-bold">AVANT</p>
|
||||
<img id="beforePreview" class="img-preview border img-fluid" src="#" alt="Photo avant">
|
||||
</div>
|
||||
|
||||
<div class="col-12 col-md-6 text-center">
|
||||
<p class="fw-bold">APRÈS</p>
|
||||
<img id="afterPreview" class="img-preview border img-fluid" src="#" alt="Photo après">
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- Bouton retour -->
|
||||
<div class="text-center mt-4">
|
||||
<a href="../html/liste_avant_apres.html" class="btn btn-secondary">
|
||||
Retour à la liste
|
||||
</a>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<script src="../js/voir_avant_apres.js"></script>
|
||||
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
@@ -1,103 +0,0 @@
|
||||
// ===============================
|
||||
// Données simulées (à remplacer plus tard par une BDD)
|
||||
// ===============================
|
||||
let galleryPairs = [
|
||||
{
|
||||
id: 1,
|
||||
titre: "Petit chien poils longs",
|
||||
|
||||
|
||||
},
|
||||
{
|
||||
id: 2,
|
||||
titre: "Coupe ciseaux",
|
||||
|
||||
|
||||
}
|
||||
];
|
||||
|
||||
// Sélecteurs
|
||||
const tableBody = document.getElementById("prestationTableBody");
|
||||
const succesDeleteMsg = document.getElementById("succesDeleteMsg");
|
||||
|
||||
// Modal & bouton de confirmation
|
||||
const deleteModalEl = document.getElementById("deleteModal");
|
||||
const confirmDeleteBtn = document.getElementById("confirmDeleteBtn");
|
||||
const deleteModal = new bootstrap.Modal(deleteModalEl);
|
||||
|
||||
// ID de la paire en attente de suppression
|
||||
let pairIdToDelete = null;
|
||||
|
||||
// ===============================
|
||||
// Fonction d'affichage
|
||||
// ===============================
|
||||
function displayPairs() {
|
||||
tableBody.innerHTML = ""; // reset tableau
|
||||
|
||||
galleryPairs.forEach(pair => {
|
||||
const row = document.createElement("tr");
|
||||
|
||||
row.innerHTML = `
|
||||
<td>${pair.titre}</td>
|
||||
|
||||
|
||||
<td class="text-center text-md-start">
|
||||
<div class="d-flex flex-column flex-md-row justify-content-center justify-content-md-end gap-2">
|
||||
|
||||
|
||||
|
||||
<!-- Bouton Modifier -->
|
||||
<a href="../html/modifier_avant_apres.html?id=${pair.id}"
|
||||
class="btn btn-outline-primary btn-sm">
|
||||
Modifier
|
||||
</a>
|
||||
|
||||
<!-- Bouton Supprimer -->
|
||||
<button class="btn btn-outline-danger btn-sm" onclick="openDeleteModal(${pair.id})">
|
||||
Supprimer
|
||||
</button>
|
||||
</div>
|
||||
</td>
|
||||
`;
|
||||
|
||||
tableBody.appendChild(row);
|
||||
});
|
||||
}
|
||||
|
||||
// ===============================
|
||||
// Ouvrir le modal de suppression
|
||||
// ===============================
|
||||
function openDeleteModal(id) {
|
||||
pairIdToDelete = id; // on mémorise l'id
|
||||
deleteModal.show(); // on ouvre le modal
|
||||
}
|
||||
|
||||
// ===============================
|
||||
// Fonction de suppression réelle
|
||||
// ===============================
|
||||
function deletePair(id) {
|
||||
galleryPairs = galleryPairs.filter(pair => pair.id !== id);
|
||||
displayPairs();
|
||||
|
||||
succesDeleteMsg.classList.remove("d-none");
|
||||
|
||||
setTimeout(() => {
|
||||
succesDeleteMsg.classList.add("d-none");
|
||||
}, 2000);
|
||||
}
|
||||
|
||||
// ===============================
|
||||
// Clic sur "Supprimer" dans le modal
|
||||
// ===============================
|
||||
confirmDeleteBtn.addEventListener("click", () => {
|
||||
if (pairIdToDelete !== null) {
|
||||
deletePair(pairIdToDelete);
|
||||
pairIdToDelete = null;
|
||||
}
|
||||
deleteModal.hide();
|
||||
});
|
||||
|
||||
// ===============================
|
||||
// Chargement initial
|
||||
// ===============================
|
||||
displayPairs();
|
||||
@@ -1,61 +0,0 @@
|
||||
// Exemple BDD
|
||||
const prestations = [
|
||||
{
|
||||
id: 1,
|
||||
titre: "Toilettage complet",
|
||||
type: "Chien",
|
||||
description: "• Bain complet \n• Séchage \n• Coupe aux ciseaux\n• Nettoyage des oreilles",
|
||||
prixMin: 35,
|
||||
prixMax: 60
|
||||
},
|
||||
{
|
||||
id: 2,
|
||||
titre: "Toilettage express",
|
||||
type: "Chat",
|
||||
description: "• Bain rapide\n• Séchage\n• Brossage",
|
||||
prixMin: 20,
|
||||
prixMax: 35
|
||||
}
|
||||
];
|
||||
|
||||
// Sélection des éléments
|
||||
const tableBody = document.getElementById('prestationTableBody');
|
||||
const successDeleteMsg = document.getElementById('successDeleteMsg');
|
||||
|
||||
// Fonction pour extrait description
|
||||
function extrait(desc, limite = 60) {
|
||||
return desc.length > limite ? desc.substring(0, limite) + '...' : desc;
|
||||
}
|
||||
|
||||
// Affichage du tableau
|
||||
function afficherPrestations() {
|
||||
tableBody.innerHTML = '';
|
||||
|
||||
prestations.forEach((p, index) => {
|
||||
const row = `
|
||||
<tr>
|
||||
<td>${p.titre}</td>
|
||||
<td>${p.type}</td>
|
||||
<td>${extrait(p.description.replace(/\n/g, " "))}</td>
|
||||
<td>${p.prixMin}€ - ${p.prixMax}€</td>
|
||||
|
||||
<td class="text-center action-btns">
|
||||
<a href="consulter_prestation.html?id=${p.id}" class="btn btn-info btn-sm">Voir</a>
|
||||
<a href="../../prestations/modifier_prestation/modifier_prestation.html?id=${p.id}" class="btn btn-warning btn-sm">Modifier</a>
|
||||
<button class="btn btn-danger btn-sm" onclick="supprimerPrestation(${index})">Supprimer</button>
|
||||
</td>
|
||||
</tr>
|
||||
`;
|
||||
tableBody.innerHTML += row;
|
||||
});
|
||||
}
|
||||
|
||||
afficherPrestations();
|
||||
|
||||
// Suppression
|
||||
function supprimerPrestation(index) {
|
||||
prestations.splice(index, 1);
|
||||
afficherPrestations();
|
||||
|
||||
successDeleteMsg.classList.remove("d-none");
|
||||
}
|
||||
@@ -1,87 +0,0 @@
|
||||
// Simulation BDD slider
|
||||
let slides = [
|
||||
{ id: 1, image: "slide1.webp", alt: "Chien toiletté", title: "Promo du mois", order: 1 },
|
||||
{ id: 2, image: "slide2.webp", alt: "Avant / Après", title: "", order: 2 },
|
||||
{ id: 3, image: "slide3.webp", alt: "Coupe ciseaux", title: "Nouveauté", order: 3 }
|
||||
];
|
||||
|
||||
const tableBody = document.getElementById("sliderTableBody");
|
||||
const successMsg = document.getElementById("successMsg");
|
||||
|
||||
function afficherSlides() {
|
||||
|
||||
// trier par ordre
|
||||
slides.sort((a, b) => a.order - b.order);
|
||||
|
||||
tableBody.innerHTML = "";
|
||||
|
||||
slides.forEach((slide, index) => {
|
||||
const row = `
|
||||
<tr>
|
||||
<td><img src="#" alt="${slide.alt}" class="miniature"></td>
|
||||
|
||||
<td>${slide.alt}</td>
|
||||
<td>${slide.title || "-"}</td>
|
||||
<td>${slide.order}</td>
|
||||
|
||||
<td class="text-center action-buttons">
|
||||
<button class="btn btn-secondary btn-sm" onclick="monter(${index})">↑</button>
|
||||
<button class="btn btn-secondary btn-sm" onclick="descendre(${index})">↓</button>
|
||||
|
||||
<a href="../../slider/modifier_slider/modifier_slider.html?id=${slide.id}"
|
||||
class="btn btn-warning btn-sm">Modifier</a>
|
||||
|
||||
|
||||
<button class="btn btn-danger btn-sm" onclick="supprimerSlide(${index})">Supprimer</button>
|
||||
</td>
|
||||
</tr>
|
||||
`;
|
||||
tableBody.innerHTML += row;
|
||||
});
|
||||
}
|
||||
|
||||
afficherSlides();
|
||||
|
||||
// Suppression
|
||||
function supprimerSlide(index) {
|
||||
if (confirm("Voulez-vous vraiment supprimer cette image du slider ?")) {
|
||||
slides.splice(index, 1);
|
||||
|
||||
// Réordonner après suppression
|
||||
slides.forEach((s, i) => s.order = i + 1);
|
||||
|
||||
afficherSlides();
|
||||
|
||||
successMsg.textContent = "Image du slider supprimée avec succès.";
|
||||
successMsg.classList.remove("d-none");
|
||||
}
|
||||
}
|
||||
|
||||
// Monter
|
||||
function monter(index) {
|
||||
if (index === 0) return; // déjà en haut
|
||||
|
||||
[slides[index - 1], slides[index]] = [slides[index], slides[index - 1]];
|
||||
|
||||
// recalcul ordre
|
||||
slides.forEach((s, i) => s.order = i + 1);
|
||||
|
||||
afficherSlides();
|
||||
|
||||
successMsg.textContent = "Ordre mis à jour.";
|
||||
successMsg.classList.remove("d-none");
|
||||
}
|
||||
|
||||
// Descendre
|
||||
function descendre(index) {
|
||||
if (index === slides.length - 1) return; // déjà en bas
|
||||
|
||||
[slides[index], slides[index + 1]] = [slides[index + 1], slides[index]];
|
||||
|
||||
slides.forEach((s, i) => s.order = i + 1);
|
||||
|
||||
afficherSlides();
|
||||
|
||||
successMsg.textContent = "Ordre mis à jour.";
|
||||
successMsg.classList.remove("d-none");
|
||||
}
|
||||
@@ -1,58 +0,0 @@
|
||||
// ===============================
|
||||
// Données simulées (à remplacer plus tard par BDD / API)
|
||||
// ===============================
|
||||
let galleryPairs = [
|
||||
{
|
||||
id: 1,
|
||||
titre: "Petit chien poils longs",
|
||||
type: "Chien",
|
||||
avant: "../../img/avant1.jpg",
|
||||
apres: "../../img/apres1.jpg"
|
||||
},
|
||||
{
|
||||
id: 2,
|
||||
titre: "Coupe ciseaux",
|
||||
type: "Chat",
|
||||
avant: "../../img/avant2.jpg",
|
||||
apres: "../../img/apres2.jpg"
|
||||
}
|
||||
];
|
||||
|
||||
// Sélecteurs
|
||||
const titleEl = document.getElementById("pairTitle");
|
||||
const beforePreview = document.getElementById("beforePreview");
|
||||
const afterPreview = document.getElementById("afterPreview");
|
||||
const errorMsg = document.getElementById("errorMsg");
|
||||
const detailsSection = document.getElementById("detailsSection");
|
||||
|
||||
// ===============================
|
||||
// Récup ID dans l'URL
|
||||
// ===============================
|
||||
function getIdFromUrl() {
|
||||
const params = new URLSearchParams(window.location.search);
|
||||
return parseInt(params.get("id"));
|
||||
}
|
||||
|
||||
// ===============================
|
||||
// Charger les infos de la paire
|
||||
// ===============================
|
||||
function loadPairDetails() {
|
||||
const id = getIdFromUrl();
|
||||
const pair = galleryPairs.find(p => p.id === id);
|
||||
|
||||
if (!pair) {
|
||||
errorMsg.classList.remove("d-none");
|
||||
detailsSection.classList.add("d-none");
|
||||
return;
|
||||
}
|
||||
|
||||
// Affichage du titre
|
||||
titleEl.textContent = pair.titre;
|
||||
|
||||
// Affichage des images
|
||||
beforePreview.src = pair.avant;
|
||||
afterPreview.src = pair.apres;
|
||||
}
|
||||
|
||||
// Initialisation
|
||||
loadPairDetails();
|
||||
Reference in New Issue
Block a user