Compare commits
15 Commits
e2fe18ec04
...
david
| Author | SHA1 | Date | |
|---|---|---|---|
| 21dab81e7a | |||
| 77f43fff95 | |||
| c4a6dcf798 | |||
| 63592a114d | |||
| 74a04ea355 | |||
| 5b0edbccca | |||
| ad9e8b8308 | |||
| fc19007b05 | |||
| efad1b078e | |||
| 16ab4707e2 | |||
| 84d8f1c481 | |||
| 9e80b99abe | |||
| 2125bfb126 | |||
| a0e14bfa92 | |||
| 5ee026f439 |
@@ -7,22 +7,14 @@
|
|||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
||||||
<script src="https://cdn.ckeditor.com/ckeditor5/39.0.1/classic/ckeditor.js"></script>
|
<script src="https://cdn.ckeditor.com/ckeditor5/39.0.1/classic/ckeditor.js"></script>
|
||||||
<script src="https://cdn.ckeditor.com/ckeditor5/39.0.1/classic/translations/fr.js"></script>
|
<script src="https://cdn.ckeditor.com/ckeditor5/39.0.1/classic/translations/fr.js"></script>
|
||||||
|
<link rel="stylesheet" href="../../css/blog.css">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
body {
|
|
||||||
background: #f4f6f9;
|
|
||||||
}
|
|
||||||
.container {
|
|
||||||
|
|
||||||
margin: 40px auto;
|
|
||||||
}
|
|
||||||
.ck-editor__editable {
|
|
||||||
min-height: 350px;
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
@@ -144,7 +136,7 @@
|
|||||||
|
|
||||||
<!--Boutons-->
|
<!--Boutons-->
|
||||||
<div class="d-flex gap-3 mt-4">
|
<div class="d-flex gap-3 mt-4">
|
||||||
<a href="../html/liste_categorie_article.html" class="btn btn-secondary w-50">Annuler</a>
|
<a href="../html/accueil_blog.html" class="btn btn-secondary w-50">Annuler</a>
|
||||||
<button type="submit" class="btn btn-primary w-50">Ajouter</button>
|
<button type="submit" class="btn btn-primary w-50">Ajouter</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -152,7 +144,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script src="../js/ajouter_article.js"></script>
|
<script src="../js/ajouter_article.js"></script>
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
<script src="https://cdn.tiny.cloud/1/1up68ybfp3crmpssl9o7pu6d0e8v3okcnsinhoujnmak7wft/tinymce/6/tinymce.min.js" referrerpolicy="origin"></script>
|
<script src="https://cdn.tiny.cloud/1/1up68ybfp3crmpssl9o7pu6d0e8v3okcnsinhoujnmak7wft/tinymce/6/tinymce.min.js" referrerpolicy="origin"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
@@ -166,27 +158,9 @@ tinymce.init({
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!--ClassicEditor
|
|
||||||
.create(document.querySelector('#articleContent'), {
|
|
||||||
language: 'fr',
|
|
||||||
toolbar: [
|
|
||||||
'heading',
|
|
||||||
'bold', 'italic',
|
|
||||||
'bulletedList', 'numberedList',
|
|
||||||
'undo', 'redo'
|
|
||||||
]
|
|
||||||
})
|
|
||||||
.catch(error => {
|
|
||||||
console.error(error);
|
|
||||||
});
|
|
||||||
@@ -97,14 +97,14 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="d-flex gap-3 mt-4">
|
<div class="d-flex gap-3 mt-4">
|
||||||
<a href="../html/liste_categorie_article.html" class="btn btn-secondary w-50">Annuler</a>
|
<a href="../html/accueil_blog.html" class="btn btn-secondary w-50">Annuler</a>
|
||||||
<button type="submit" class="btn btn-primary w-50">Ajouter</button>
|
<button type="submit" class="btn btn-primary w-50">Ajouter</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script src="../js/ajouter_categorie.js"></script>
|
<script src="../js/ajouter_categorie.js"></script>
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
@@ -152,12 +152,12 @@
|
|||||||
<!--Publié-->
|
<!--Publié-->
|
||||||
<div class="form-check mb-3">
|
<div class="form-check mb-3">
|
||||||
<input class="form-check-input" type="checkbox" id="articlePublished" checked>
|
<input class="form-check-input" type="checkbox" id="articlePublished" checked>
|
||||||
<label class="form-check-label">Publié</label>
|
<label class="form-check-label">Publié (sera publié sur facebook)</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!--Boutons-->
|
<!--Boutons-->
|
||||||
<div class="d-flex gap-3 mt-4">
|
<div class="d-flex gap-3 mt-4">
|
||||||
<a href="../../blog/html/liste_categorie_article.html" class="btn btn-secondary w-50">Annuler</a>
|
<a href="../../blog/html/accueil_blog.html" class="btn btn-secondary w-50">Annuler</a>
|
||||||
<button type="submit" class="btn btn-primary w-50">Enregistrer</button>
|
<button type="submit" class="btn btn-primary w-50">Enregistrer</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -179,7 +179,7 @@
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<script src="../js/modifier_article.js"></script>
|
<script src="../js/modifier_article.js"></script>
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
@@ -5,17 +5,9 @@
|
|||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>Modifier une catégorie</title>
|
<title>Modifier une catégorie</title>
|
||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" href="../../css/blog.css">
|
||||||
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
background: #f4f6f981;
|
|
||||||
|
|
||||||
}
|
|
||||||
.container {
|
|
||||||
|
|
||||||
margin: 50px auto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
@@ -75,10 +67,7 @@
|
|||||||
<div class="container">
|
<div class="container">
|
||||||
<h2 class="mb-5 text-center">Modifier une catégorie</h2>
|
<h2 class="mb-5 text-center">Modifier une catégorie</h2>
|
||||||
|
|
||||||
<div id="errorMsg" class="alert alert-danger d-none">Veuillez ezmplir tous les champs obligatoires</div>
|
|
||||||
|
|
||||||
<div id="successMsg" class="alert alert-success d-none">La catégorie a été modifiée avec succès !</div>
|
|
||||||
|
|
||||||
<form id="modifierCategorie">
|
<form id="modifierCategorie">
|
||||||
|
|
||||||
|
|
||||||
@@ -95,7 +84,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="d-flex gap-3 mt-4">
|
<div class="d-flex gap-3 mt-4">
|
||||||
<a href="../html/liste_categorie_article.html" class="btn btn-secondary w-50">Annuler</a>
|
<a href="../html/accueil_blog.html" class="btn btn-secondary w-50">Annuler</a>
|
||||||
<button type="submit" class="btn btn-primary w-50">Enregistrer</button>
|
<button type="submit" class="btn btn-primary w-50">Enregistrer</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -103,7 +92,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script src="../js/modifier_categorie.js"></script>
|
<script src="../js/modifier_categorie.js"></script>
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -17,8 +17,9 @@ form.addEventListener('submit', function(e) {
|
|||||||
|
|
||||||
const titre = titleField.value.trim().toLowerCase();
|
const titre = titleField.value.trim().toLowerCase();
|
||||||
const fichierImage = imgField.files[0];
|
const fichierImage = imgField.files[0];
|
||||||
const contenu = tinymce.get("articleContent").getContent(); // ← CORRECTION IMPORTANTE
|
const contenu = tinymce.get("articleContent").getContent();
|
||||||
const categorie = categoryField.value;
|
const categorie = categoryField.value;
|
||||||
|
const published = publishedField.checked; // récupère la case cochée
|
||||||
|
|
||||||
// Reset messages
|
// Reset messages
|
||||||
errorEmpty.classList.add('d-none');
|
errorEmpty.classList.add('d-none');
|
||||||
@@ -62,23 +63,44 @@ form.addEventListener('submit', function(e) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Simuler enregistrement
|
// Simuler enregistrement
|
||||||
titreExistants.push(titre);
|
titreExistants.push(titre);
|
||||||
|
|
||||||
|
|
||||||
|
// CRÉATION DE L'ARTICLE
|
||||||
|
|
||||||
|
const nouvelArticle = {
|
||||||
|
id: Date.now(),
|
||||||
|
titre: titleField.value.trim(),
|
||||||
|
contenu: contenu,
|
||||||
|
categorie: categorie,
|
||||||
|
published: published, // valeur TRUE/FALSE pour afficher le badge Facebook
|
||||||
|
date: new Date().toISOString()
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// SAUVEGARDE DANS LOCALSTORAGE
|
||||||
|
|
||||||
|
let articles = JSON.parse(localStorage.getItem("articles")) || [];
|
||||||
|
articles.push(nouvelArticle);
|
||||||
|
localStorage.setItem("articles", JSON.stringify(articles));
|
||||||
|
|
||||||
|
console.log("Article enregistré :", nouvelArticle);
|
||||||
|
|
||||||
// Succès
|
// Succès
|
||||||
successMsg.classList.remove('d-none');
|
successMsg.classList.remove('d-none');
|
||||||
|
|
||||||
// Redirection
|
// Redirection
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
window.location.href = "../html/liste_categorie_article.html";
|
window.location.href = "../html/accueil_blog.html";
|
||||||
}, 1000);
|
}, 1000);
|
||||||
});
|
});
|
||||||
|
|
||||||
// TinyMCE
|
// TinyMCE INIT
|
||||||
tinymce.init({
|
tinymce.init({
|
||||||
selector: '#articleContent',
|
selector: '#articleContent',
|
||||||
height: 400,
|
height: 400,
|
||||||
language: 'fr',
|
language: 'fr',
|
||||||
plugins: 'lists fullscreen',
|
plugins: 'lists fullscreen',
|
||||||
toolbar: 'undo redo | bold italic underline | bullist numlist | fullscreen',
|
toolbar: 'undo redo | bold italic underline | bullist numlist | fullscreen'
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ existingCategories.push(nom);
|
|||||||
|
|
||||||
// Redirection après 1 seconde
|
// Redirection après 1 seconde
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
window.location.href = "../html/liste_categorie_article.html";
|
window.location.href = "../html/accueil_blog.html";
|
||||||
}, 1000);
|
}, 1000);
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,14 +1,67 @@
|
|||||||
|
// Sélecteur du tableau
|
||||||
|
const articlesTableBody = document.getElementById("articlesTableBody");
|
||||||
|
|
||||||
|
// Charger les articles depuis le localStorage
|
||||||
|
let articles = JSON.parse(localStorage.getItem("articles")) || [];
|
||||||
|
|
||||||
|
// Fonction d'affichage des articles
|
||||||
|
function afficherArticles() {
|
||||||
|
articlesTableBody.innerHTML = ""; // Nettoie le tableau
|
||||||
|
|
||||||
|
if (articles.length === 0) {
|
||||||
|
articlesTableBody.innerHTML = `
|
||||||
|
<tr>
|
||||||
|
<td colspan="2" class="text-center text-muted py-3">
|
||||||
|
Aucun article pour le moment.
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
`;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
articles.forEach(article => {
|
||||||
|
const tr = document.createElement("tr");
|
||||||
|
|
||||||
|
tr.innerHTML = `
|
||||||
|
<td>
|
||||||
|
${article.titre}
|
||||||
|
${article.published ? '<span class="badge bg-primary ms-2">Publié Facebook</span>' : ''}
|
||||||
|
</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="modifier_article.html?id=${article.id}"
|
||||||
|
class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn" data-id="${article.id}">
|
||||||
|
Supprimer
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
`;
|
||||||
|
|
||||||
|
articlesTableBody.appendChild(tr);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gestion de suppression
|
||||||
document.addEventListener("click", function (e) {
|
document.addEventListener("click", function (e) {
|
||||||
const btn = e.target.closest(".delete-btn");
|
const btn = e.target.closest(".delete-btn");
|
||||||
if (!btn) return; // on a cliqué ailleurs
|
if (!btn) return;
|
||||||
|
|
||||||
// On récupère la ligne de l'article
|
|
||||||
const row = btn.closest("tr");
|
const row = btn.closest("tr");
|
||||||
const titre = row.querySelector("td").textContent.trim();
|
const titre = row.querySelector("td").textContent.trim();
|
||||||
|
const id = Number(btn.dataset.id);
|
||||||
|
|
||||||
if (confirm(`Voulez-vous vraiment supprimer l'article : "${titre}" ?`)) {
|
if (confirm(`Voulez-vous vraiment supprimer l'article : "${titre}" ?`)) {
|
||||||
row.remove(); // supprime la ligne
|
|
||||||
|
// Supprimer dans le tableau local
|
||||||
|
articles = articles.filter(article => article.id !== id);
|
||||||
|
localStorage.setItem("articles", JSON.stringify(articles));
|
||||||
|
|
||||||
|
// Supprimer visuel
|
||||||
|
row.remove();
|
||||||
|
|
||||||
alert("Article supprimé !");
|
alert("Article supprimé !");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Lancer l'affichage dès que la page charge
|
||||||
|
afficherArticles();
|
||||||
|
|||||||
@@ -55,6 +55,6 @@ form.addEventListener("submit", function (e) {
|
|||||||
|
|
||||||
// Redirection après succès
|
// Redirection après succès
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
window.location.href = "../../blog/html/liste_categorie_article.html";
|
window.location.href = "../../blog/html/accueil_blog.html";
|
||||||
}, 1500);
|
}, 1500);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,26 +1,37 @@
|
|||||||
|
|
||||||
const form = document.getElementById("modifierCategorie");
|
const form = document.getElementById("modifierCategorie");
|
||||||
const nameField = document.getElementById("categoryName");
|
const nameField = document.getElementById("categoryName");
|
||||||
const descField = document.getElementById("categorieDescription");
|
const descField = document.getElementById("categorieDescription");
|
||||||
const errorMsg = document.getElementById("errorMsg");
|
|
||||||
const successMsg = document.getElementById("successMsg");
|
// Fonction pour afficher un message Bootstrap
|
||||||
|
function showMessage(type, message) {
|
||||||
|
// Création de l'alert
|
||||||
|
const alert = document.createElement("div");
|
||||||
|
alert.className = `alert alert-${type} mt-3`;
|
||||||
|
alert.textContent = message;
|
||||||
|
|
||||||
|
// Ajout en haut du formulaire
|
||||||
|
form.prepend(alert);
|
||||||
|
|
||||||
|
// Suppression automatique après 2 secondes
|
||||||
|
setTimeout(() => {
|
||||||
|
alert.remove();
|
||||||
|
}, 2000);
|
||||||
|
}
|
||||||
|
|
||||||
form.addEventListener("submit", function (e) {
|
form.addEventListener("submit", function (e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
// Vérification des champs obligatoires
|
// Vérification des champs obligatoires
|
||||||
if (nameField.value.trim() === "" || descField.value.trim() === "") {
|
if (nameField.value.trim() === "" || descField.value.trim() === "") {
|
||||||
errorMsg.classList.remove("d-none");
|
showMessage("danger", "Veuillez remplir tous les champs obligatoires");
|
||||||
successMsg.classList.add("d-none");
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Succès
|
// Message succès
|
||||||
errorMsg.classList.add("d-none");
|
showMessage("success", "La catégorie a été modifiée avec succès !");
|
||||||
successMsg.classList.remove("d-none");
|
|
||||||
|
|
||||||
// Redirection après succès
|
// Redirection après succès
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
window.location.href = "../html/liste_categorie_article.html";
|
window.location.href = "../html/accueil_blog.html";
|
||||||
}, 1500);
|
}, 1500);
|
||||||
});
|
});
|
||||||
|
|||||||
182
citations/html/accueil.html
Normal file
182
citations/html/accueil.html
Normal file
@@ -0,0 +1,182 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Citations - L'Il'eau chiens - Admin</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="shortcut icon" href="favicon.png" type="image/png">
|
||||||
|
<link rel="stylesheet" href="/css/style.css">
|
||||||
|
<link rel="stylesheet" href="/css/citations.css">
|
||||||
|
<link rel="shortcut icon" href="/favicon.png" type="image/png">
|
||||||
|
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<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 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 renseignements</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link left-label" href="#">Partenaires</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link active left-label" href="#">Citations</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>
|
||||||
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
|
<header>
|
||||||
|
<h1 class="title my-4 fs-2">Liste des citations</h1>
|
||||||
|
</header>
|
||||||
|
<main>
|
||||||
|
<div class="ajouter">
|
||||||
|
<a href="#" class="btn btn-primary btn-sm my-2">Ajouter une citation</a>
|
||||||
|
</div>
|
||||||
|
<section class="chiens my-4">
|
||||||
|
<h2 class="fs-4">Citations chiens</h2>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Citations</th>
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>Le chien est le seul être sur terre qui vous aime plus qu'il ne s'aime lui-même. (Josh Billings)</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-primary me-2">Modifier</a>
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-danger">Supprimer</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Un chien est la seule chose sur terre qui vous aime plus qu'il ne s'aime lui-même. (Josh Billings)</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-primary me-2">Modifier</a>
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-danger">Supprimer</a>
|
||||||
|
</td>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section class="chats my-4">
|
||||||
|
<h2 class="fs-4">Citations chats</h2>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Citations</th>
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>Le chien est le seul être sur terre qui vous aime plus qu'il ne s'aime lui-même. (Josh Billings)</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-primary me-2">Modifier</a>
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-danger">Supprimer</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Un chien est la seule chose sur terre qui vous aime plus qu'il ne s'aime lui-même. (Josh Billings)</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-primary me-2">Modifier</a>
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-danger">Supprimer</a>
|
||||||
|
</td>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section class="chats my-4">
|
||||||
|
<h2 class="fs-4">Citations divers</h2>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Citations</th>
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>Le chien est le seul être sur terre qui vous aime plus qu'il ne s'aime lui-même. (Josh Billings)</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-primary me-2">Modifier</a>
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-danger">Supprimer</a>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Un chien est la seule chose sur terre qui vous aime plus qu'il ne s'aime lui-même. (Josh Billings)</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-primary me-2">Modifier</a>
|
||||||
|
<a href="#" class="btn btn-sm btn-outline-danger">Supprimer</a>
|
||||||
|
</td>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</section>
|
||||||
|
</main>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
<script src="/node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
<script src="../js/contentReduct.js"></script>
|
||||||
|
|
||||||
|
</html>
|
||||||
43
citations/js/contentReduct.js
Normal file
43
citations/js/contentReduct.js
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
/**
|
||||||
|
* Réduit le contenu des cellules td des tableaux
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const BREAKPOINT_SM = 1000;
|
||||||
|
(() => {
|
||||||
|
// Récupère les cellules td (premier d'un tr) à traiter
|
||||||
|
const getTargetCells = () => {
|
||||||
|
const tbodyRows = Array.from(document.querySelectorAll("tbody tr"));
|
||||||
|
let cells = tbodyRows.map((row) => row.querySelector("td")).filter(Boolean);
|
||||||
|
if (cells.length === 0) {
|
||||||
|
const allRows = Array.from(document.querySelectorAll("tr"));
|
||||||
|
cells = allRows.map((row) => row.querySelector("td")).filter(Boolean);
|
||||||
|
}
|
||||||
|
return cells;
|
||||||
|
};
|
||||||
|
|
||||||
|
const tdElts = getTargetCells();
|
||||||
|
|
||||||
|
tdElts.forEach((td) => {
|
||||||
|
if (!td.dataset.fullText) {
|
||||||
|
td.dataset.fullText = td.textContent.trim();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const applyTruncation = () => {
|
||||||
|
const narrow = window.innerWidth < BREAKPOINT_SM;
|
||||||
|
tdElts.forEach((td) => {
|
||||||
|
const full = td.dataset.fullText ?? td.textContent;
|
||||||
|
const text = (full || "").trim();
|
||||||
|
if (narrow) {
|
||||||
|
td.textContent = text.length > 40 ? text.slice(0, 40) + '...': text;
|
||||||
|
} else {
|
||||||
|
td.textContent = full;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
applyTruncation();
|
||||||
|
window.addEventListener("resize", applyTruncation);
|
||||||
|
})();
|
||||||
11
css/blog.css
Normal file
11
css/blog.css
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
|
||||||
|
body {
|
||||||
|
background: #f4f6f9;
|
||||||
|
}
|
||||||
|
.container {
|
||||||
|
|
||||||
|
margin: 40px auto;
|
||||||
|
}
|
||||||
|
.ck-editor__editable {
|
||||||
|
min-height: 350px;
|
||||||
|
}
|
||||||
0
css/citations.css
Normal file
0
css/citations.css
Normal file
@@ -1,16 +1,19 @@
|
|||||||
/*=============================================================================
|
/*=============================================================================
|
||||||
Header Navbar Styles
|
Header Navbar Styles
|
||||||
=============================================================================*/
|
=============================================================================*/
|
||||||
|
a.nav-link{
|
||||||
|
font-size: .95rem;
|
||||||
|
}
|
||||||
|
|
||||||
.navbar-brand {
|
.navbar-brand {
|
||||||
font-size: 1.2rem;
|
font-size: 1.1rem;
|
||||||
line-height: 1;
|
line-height: 1;
|
||||||
padding-top: 0.25rem;
|
padding-top: 0.25rem;
|
||||||
padding-bottom: 0.25rem;
|
padding-bottom: 0.25rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.brand-sep {
|
.brand-sep {
|
||||||
height: 1.2rem;
|
height: .8rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
38
header.html
38
header.html
@@ -7,35 +7,10 @@
|
|||||||
<title>CE sera le titre de la page</title>
|
<title>CE sera le titre de la page</title>
|
||||||
<link href="node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
|
<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="node_modules/bs-icon/icons.css">
|
||||||
|
<link rel="shortcut icon" href="favicon.png" type="image/png">
|
||||||
|
<link rel="stylesheet" href="css/style.css">
|
||||||
|
|
||||||
<style>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.navbar-brand { font-size: 1.2rem; line-height: 1; padding-top: 0.25rem; padding-bottom: 0.25rem; }
|
|
||||||
|
|
||||||
.brand-sep { height: 1.2rem; }
|
|
||||||
|
|
||||||
|
|
||||||
@media (max-width: 1399.98px) {
|
|
||||||
.navbar .nav-item {
|
|
||||||
background-color: var(--bs-light);
|
|
||||||
border: 1px solid var(--bs-border-color);
|
|
||||||
border-radius: .25rem;
|
|
||||||
margin-bottom: .375rem;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
#navbarSupportedContent > ul:first-child { margin-top: .5rem; }
|
|
||||||
#navbarSupportedContent > ul:last-child { margin-top: 1rem; }
|
|
||||||
|
|
||||||
.bi{
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
@@ -67,11 +42,14 @@
|
|||||||
<a class="nav-link left-label" href="#">FAQ</a>
|
<a class="nav-link left-label" href="#">FAQ</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a class="nav-link left-label" href="#">Fiche de renseignements</a>
|
<a class="nav-link left-label" href="#">Fiche renseignements</a>
|
||||||
</li>
|
</li>
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<a class="nav-link left-label" href="#">Partenaires</a>
|
<a class="nav-link left-label" href="#">Partenaires</a>
|
||||||
</li>
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link left-label" href="#">Citations</a>
|
||||||
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
@@ -105,7 +83,7 @@
|
|||||||
<main class="my-5 fs-6">
|
<main class="my-5 fs-6">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<header>
|
<header>
|
||||||
<h1 class="title fs-2">Titre de la page</h1>
|
<h1 class="title my-4 fs-2">Titre de la page</h1>
|
||||||
</header>
|
</header>
|
||||||
<main>
|
<main>
|
||||||
Contenu de la page
|
Contenu de la page
|
||||||
|
|||||||
3
package-lock.json
generated
3
package-lock.json
generated
@@ -76,8 +76,7 @@
|
|||||||
"node_modules/scheduler": {
|
"node_modules/scheduler": {
|
||||||
"version": "0.27.0",
|
"version": "0.27.0",
|
||||||
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.27.0.tgz",
|
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.27.0.tgz",
|
||||||
"integrity": "sha512-eNv+WrVbKu1f3vbYJT/xtiF5syA5HPIMtf9IgY/nKg0sWqzAUEvqY/xm7OcZc/qafLx/iO9FgOmeSAp4v5ti/Q==",
|
"integrity": "sha512-eNv+WrVbKu1f3vbYJT/xtiF5syA5HPIMtf9IgY/nKg0sWqzAUEvqY/xm7OcZc/qafLx/iO9FgOmeSAp4v5ti/Q=="
|
||||||
"peer": true
|
|
||||||
},
|
},
|
||||||
"node_modules/tinymce": {
|
"node_modules/tinymce": {
|
||||||
"version": "8.2.2",
|
"version": "8.2.2",
|
||||||
|
|||||||
@@ -82,77 +82,85 @@
|
|||||||
</header>
|
</header>
|
||||||
|
|
||||||
|
|
||||||
<div class="container mt-5">
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
<h1 class="mb-4 text-center">Ajouter un résultat en images (Avant / Après)</h1>
|
<header>
|
||||||
|
<h1 class="title fs-2">Ajouter un résultat en images (Avant / Après)</h1>
|
||||||
<!-- Message succès -->
|
<!-- Message succès -->
|
||||||
<div id="successMsg" class="alert alert-success d-none">
|
<div id="successMsg" class="alert alert-success d-none">
|
||||||
Nouveau résultat ajouté avec succès !
|
Nouveau résultat ajouté avec succès !
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Message erreur -->
|
|
||||||
<div id="errorMsg" class="alert alert-danger d-none">
|
|
||||||
Merci de remplir tous les champs obligatoires.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Erreur : format invalide -->
|
|
||||||
<div id="errorFormat" class="alert alert-danger d-none">
|
|
||||||
Format d'image invalide. Formats acceptés : JPG, PNG, WEBP.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<form id="addPairForm" class="mt-3">
|
|
||||||
|
|
||||||
<!-- Titre / label -->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold" for="pairTitle">Titre du résultat (obligatoire)</label>
|
|
||||||
<input type="text" id="pairTitle" class="form-control" required>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Type -->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold" for="pairType">Type (obligatoire)</label>
|
|
||||||
<select id="pairType" class="form-select" required>
|
|
||||||
<option value="">-- Choisir --</option>
|
|
||||||
<option value="Chien">Chien</option>
|
|
||||||
<option value="Chat">Chat</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image AVANT -->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold" for="beforeImage">Image AVANT (obligatoire, formats acceptés : jpg,
|
|
||||||
png, webp)</label>
|
|
||||||
<input type="file" id="beforeImage" class="form-control" accept="image/*" required>
|
|
||||||
|
|
||||||
<img id="beforePreview" class="img-preview border mt-2" src="#" alt="image avant">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image APRÈS -->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold" for="afterImage">Image APRÈS (obligatoire, formats acceptés : jpg,
|
|
||||||
png, webp)</label>
|
|
||||||
<input type="file" id="afterImage" class="form-control" accept="image/*" required>
|
|
||||||
|
|
||||||
<img id="afterPreview" class="img-preview border mt-2" src="#" alt="image après">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Boutons : empilés en mobile, côte à côte en md+ -->
|
|
||||||
<div class="row mt-4 g-3">
|
|
||||||
<div class="col-12 col-md-6">
|
|
||||||
<a href="../html/liste_avant_apres.html" class="btn btn-secondary w-100">
|
|
||||||
Annuler
|
|
||||||
</a>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="col-12 col-md-6">
|
|
||||||
<button type="submit" class="btn btn-primary w-100">
|
|
||||||
Ajouter
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</form>
|
<!-- Message erreur -->
|
||||||
</div>
|
<div id="errorMsg" class="alert alert-danger d-none">
|
||||||
|
Merci de remplir tous les champs obligatoires.
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Erreur : format invalide -->
|
||||||
|
<div id="errorFormat" class="alert alert-danger d-none">
|
||||||
|
Format d'image invalide. Formats acceptés : JPG, PNG, WEBP.
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
<div class="section">
|
||||||
|
|
||||||
|
<form id="addPairForm" class="mt-3">
|
||||||
|
|
||||||
|
<!-- Titre -->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold" for="pairTitle">Titre du résultat (obligatoire)</label>
|
||||||
|
<input type="text" id="pairTitle" class="form-control" required>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Type -->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold" for="pairType">Type (obligatoire)</label>
|
||||||
|
<select id="pairType" class="form-select" required>
|
||||||
|
<option value="">-- Choisir --</option>
|
||||||
|
<option value="Chien">Chien</option>
|
||||||
|
<option value="Chat">Chat</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Image AVANT -->
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold" for="beforeImage">Image AVANT (obligatoire, formats acceptés :
|
||||||
|
jpg,
|
||||||
|
png, webp)</label>
|
||||||
|
<input type="file" id="beforeImage" class="form-control" accept="image/*" required>
|
||||||
|
|
||||||
|
<img id="beforePreview" class="img-preview border mt-2" src="#" alt="image avant">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Image APRÈS -->
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold" for="afterImage">Image APRÈS (obligatoire, formats acceptés :
|
||||||
|
jpg,
|
||||||
|
png, webp)</label>
|
||||||
|
<input type="file" id="afterImage" class="form-control" accept="image/*" required>
|
||||||
|
|
||||||
|
<img id="afterPreview" class="img-preview border mt-2" src="#" alt="image après">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Boutons : empilés en mobile, côte à côte en md+ -->
|
||||||
|
<div class="row mt-4 g-3">
|
||||||
|
<div class="col-12 col-md-6">
|
||||||
|
<a href="../html/liste_avant_apres.html" class="btn btn-secondary w-100">
|
||||||
|
Annuler
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="col-12 col-md-6">
|
||||||
|
<button type="submit" class="btn btn-primary w-100">
|
||||||
|
Ajouter
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
|
||||||
<script src="../js/ajouter_avant_apres.js"></script>
|
<script src="../js/ajouter_avant_apres.js"></script>
|
||||||
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|||||||
@@ -85,7 +85,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<div>
|
<div class="section">
|
||||||
|
|
||||||
<div class="d-flex justify-content-start mb-4">
|
<div class="d-flex justify-content-start mb-4">
|
||||||
<a href="../html/ajouter_avant_apres.html" class="btn btn-primary">
|
<a href="../html/ajouter_avant_apres.html" class="btn btn-primary">
|
||||||
@@ -98,11 +98,8 @@
|
|||||||
<table class="table table-striped table-hover align-middle mb-0">
|
<table class="table table-striped table-hover align-middle mb-0">
|
||||||
<thead class="table-dark">
|
<thead class="table-dark">
|
||||||
<tr>
|
<tr>
|
||||||
<th>Titre résultat</th>
|
<th>Titre du résultat</th>
|
||||||
<th>Type</th>
|
<th class="text-end">Actions</th>
|
||||||
<th>Avant</th>
|
|
||||||
<th>Après</th>
|
|
||||||
<th class="text-center">Actions</th>
|
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody id="prestationTableBody">
|
<tbody id="prestationTableBody">
|
||||||
|
|||||||
@@ -1,25 +1,31 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="fr">
|
<html lang="fr">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>Liste des slides</title>
|
<title>Liste des slides</title>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
|
<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>
|
<style>
|
||||||
body {
|
body {
|
||||||
background: #f4f6f9;
|
background: #f4f6f9;
|
||||||
padding: 40px;
|
padding: 40px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.container {
|
.container {
|
||||||
max-width: 900px;
|
max-width: 900px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.miniature {
|
.miniature {
|
||||||
width: 90px;
|
width: 90px;
|
||||||
height: 60px;
|
height: 60px;
|
||||||
object-fit: cover;
|
object-fit: cover;
|
||||||
border-radius: 5px;
|
border-radius: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.action-buttons button,
|
.action-buttons button,
|
||||||
.action-buttons a {
|
.action-buttons a {
|
||||||
margin-right: 8px;
|
margin-right: 8px;
|
||||||
@@ -27,39 +33,103 @@
|
|||||||
</style>
|
</style>
|
||||||
</head>
|
</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>
|
<body>
|
||||||
|
|
||||||
<div class="container">
|
<div class="container">
|
||||||
|
|
||||||
<h2 class="text-center mb-4">Slider – Liste des images</h2>
|
<h2 class="text-center mb-4">Slider – Liste des images</h2>
|
||||||
|
|
||||||
<!-- Message succès (suppression / ordre) -->
|
<!-- Message succès (suppression / ordre) -->
|
||||||
<div id="successMsg" class="alert alert-success d-none"></div>
|
<div id="successMsg" class="alert alert-success d-none"></div>
|
||||||
|
|
||||||
<!-- Bouton ajouter -->
|
<!-- Bouton ajouter -->
|
||||||
<div class="d-flex justify-content-end mb-4">
|
<div class="d-flex justify-content-start mb-4">
|
||||||
<a href="../../slider/ajouter_slider/ajouter_slider.html" class="btn btn-primary">Ajouter une image au slider</a>
|
<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>
|
</div>
|
||||||
|
|
||||||
<table class="table table-striped table-hover align-middle">
|
<script src="../js/liste_slider.js"></script>
|
||||||
<thead class="table-dark">
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
<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="liste_slider.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
|
||||||
|
</html>
|
||||||
@@ -96,7 +96,7 @@
|
|||||||
</header>
|
</header>
|
||||||
|
|
||||||
|
|
||||||
<div>
|
<div class="section">
|
||||||
|
|
||||||
<!-- Formulaire de modification -->
|
<!-- Formulaire de modification -->
|
||||||
<form id="editPairForm" class="mt-3">
|
<form id="editPairForm" class="mt-3">
|
||||||
|
|||||||
@@ -1,74 +1,292 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="fr">
|
<html lang="fr">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>Admin - Prestations</title>
|
<title>CE sera le titre de la page</title>
|
||||||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
|
<link href="../../node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
<link rel="stylesheet" href="../../node_modules/bs-icon/icons.css">
|
||||||
<style>
|
<link rel="stylesheet" href="../../css/style.css">
|
||||||
body {
|
|
||||||
background: #f4f6f9;
|
|
||||||
padding: 40px;
|
|
||||||
}
|
|
||||||
.menu-card {
|
|
||||||
transition: 0.2s;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
.menu-card:hover {
|
|
||||||
transform: scale(1.03);
|
|
||||||
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.12);
|
|
||||||
}
|
|
||||||
.menu-icon {
|
|
||||||
font-size: 40px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
|
<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>
|
||||||
|
|
||||||
<div class="container text-center">
|
|
||||||
<h2 class="mb-5">Gestion des prestations</h2>
|
|
||||||
|
|
||||||
<div class="row g-4">
|
|
||||||
|
|
||||||
<!-- Prestations -->
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse"
|
||||||
<div class="col-md-4">
|
data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent"
|
||||||
<a href="../liste_prestation/liste_prestation.html" class="text-decoration-none">
|
aria-expanded="false" aria-label="Toggle navigation">
|
||||||
<div class="card p-4 menu-card">
|
<span class="navbar-toggler-icon"></span>
|
||||||
<div class="menu-icon">💼</div>
|
</button>
|
||||||
<h4 class="mt-3 text-dark">Gérer les prestations</h4>
|
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
||||||
<p class="text-muted">Ajouter, modifier, supprimer les prestations.</p>
|
<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>
|
||||||
</a>
|
</div>
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</header>
|
||||||
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
|
<header>
|
||||||
|
<h1 class="title fs-2">Gérer la page prestations</h1>
|
||||||
|
</header>
|
||||||
|
<main>
|
||||||
|
<section class="prestations">
|
||||||
|
|
||||||
|
<h2 class="fs-3">Gérer les prestations</h2>
|
||||||
|
|
||||||
|
<div class="accordion" id="accordionExample">
|
||||||
|
<div class="accordion-item">
|
||||||
|
<h2 class="accordion-header">
|
||||||
|
<button class="accordion-button" type="button" data-bs-toggle="collapse"
|
||||||
|
data-bs-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne">
|
||||||
|
Gèrer les prestations et leur catégorie
|
||||||
|
</button>
|
||||||
|
</h2>
|
||||||
|
<div id="collapseOne" class="accordion-collapse collapse show"
|
||||||
|
data-bs-parent="#accordionExample">
|
||||||
|
<div class="accordion-body">
|
||||||
|
Contenu de l'accordéon 1
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="accordion-item">
|
||||||
|
<h2 class="accordion-header">
|
||||||
|
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse"
|
||||||
|
data-bs-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo">
|
||||||
|
Gérer le slider
|
||||||
|
</button>
|
||||||
|
</h2>
|
||||||
|
<div id="collapseTwo" class="accordion-collapse collapse"
|
||||||
|
data-bs-parent="#accordionExample">
|
||||||
|
<div class="accordion-body">
|
||||||
|
Contenu de l'accordéon 2
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<!--
|
||||||
|
<section class="categories-prestations">
|
||||||
|
<h3 class="fs-4">Titres des cartes</h3>
|
||||||
|
<div class="mb-3">
|
||||||
|
<a href="../html/ajouter_avant_apres.html" class="btn btn-primary btn-sm">
|
||||||
|
Ajouter une catégorie
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<section class="slider">
|
||||||
|
<details open>
|
||||||
|
<summary class="fs-5 fw-semibold">Gérer le slider</summary>
|
||||||
|
<h2 class="fs-3 mt-2">Gérer le slider</h2>
|
||||||
|
<div class="mb-3">
|
||||||
|
<a href="" class="btn btn-primary btn-sm">Ajouter une slide</a>
|
||||||
|
</div>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<tr>
|
||||||
|
<td>Toilletage complet</td>
|
||||||
|
<td class="text-end">À partir de 60€</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="" class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Toilletage complet</td>
|
||||||
|
<td class="text-end">À partir de 60€</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="" class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</section>
|
||||||
|
<section class="categories-prestations">
|
||||||
|
<h3 class="fs-4">Les prestations</h3>
|
||||||
|
<div class="mb-3">
|
||||||
|
<a href="../html/ajouter_avant_apres.html" class="btn btn-sm btn-primary">
|
||||||
|
Ajouter une prestation
|
||||||
|
</table>
|
||||||
|
</details>
|
||||||
|
</div>
|
||||||
|
<section class="galerie-avant-apres">
|
||||||
|
<details open>
|
||||||
|
<summary class="fs-5 fw-semibold">Gérer la galerie avant/après</summary>
|
||||||
|
<h2 class="fs-3 mt-2">Gérer la galerie avant/après</h2>
|
||||||
|
<div class="mb-3">
|
||||||
|
<a href="../html/ajouter_avant_apres.html" class="btn btn-primary">
|
||||||
|
Ajouter un résultat avant/après
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<tr>
|
||||||
|
<td>Un nom de prestation</td>
|
||||||
|
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="" class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>prestation spécifique</td>
|
||||||
|
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="" class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
</section>
|
||||||
|
</section>
|
||||||
|
<section class="slider">
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</details>
|
||||||
|
</section>
|
||||||
|
</details>
|
||||||
|
<h2 class="fs-3 mt-2">Gérer le slider</h2>
|
||||||
|
<div class="mb-3">
|
||||||
|
<a href="" class="btn btn-primary btn-sm">Ajouter une slide</a>
|
||||||
|
</div>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Titre de la slide</th>
|
||||||
|
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>Slide 1 : coupe griffe</td>
|
||||||
|
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="" class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Slide 2 : coupe ciseaux</td>
|
||||||
|
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="" class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</section>
|
||||||
|
<section class="galerie-avant-apres">
|
||||||
|
<details close>
|
||||||
|
<summary class="fs-5 fw-semibold">
|
||||||
|
<h2 class="fs-3 mt-2">Gérer la galerie avant/après</h2>
|
||||||
|
<div class="mb-3">
|
||||||
|
<a href="../html/ajouter_avant_apres.html" class="btn btn-primary">
|
||||||
|
Ajouter un résultat avant/après
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Titre du résultat</th>
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
<tr>
|
||||||
|
<td>Petit chien poils longs</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="../html/modifier_avant_apres.html"
|
||||||
|
class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Coupe ciseaux</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="../html/modifier_avant_apres.html"
|
||||||
|
class="btn btn-sm btn-outline-primary me-1">Modifier</a>
|
||||||
|
<button class="btn btn-sm btn-outline-danger delete-btn">Supprimer</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
</summary>
|
||||||
|
</details>
|
||||||
|
|
||||||
|
</section>
|
||||||
|
-->
|
||||||
|
</main>
|
||||||
</div>
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
<!-- Slider -->
|
|
||||||
<div class="col-md-4">
|
|
||||||
<a href="../slider/liste_slider/liste_slider.html" class="text-decoration-none">
|
|
||||||
<div class="card p-4 menu-card">
|
|
||||||
<div class="menu-icon">🎞️</div>
|
|
||||||
<h4 class="mt-3 text-dark">Gérer le slider</h4>
|
|
||||||
<p class="text-muted">Images du slider de la page Prestations chiens.</p>
|
|
||||||
</div>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Avant / Après -->
|
|
||||||
<div class="col-md-4">
|
|
||||||
<a href="../avant_apres/liste_avant_apres/liste_avant_apres.html" class="text-decoration-none">
|
|
||||||
<div class="card p-4 menu-card">
|
|
||||||
<div class="menu-icon">🖼️</div>
|
|
||||||
<h4 class="mt-3 text-dark">Galerie Avant / Après</h4>
|
|
||||||
<p class="text-muted">Ajouter, modifier ou supprimer les photos.</p>
|
|
||||||
</div>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</html>
|
||||||
@@ -5,16 +5,14 @@ let galleryPairs = [
|
|||||||
{
|
{
|
||||||
id: 1,
|
id: 1,
|
||||||
titre: "Petit chien poils longs",
|
titre: "Petit chien poils longs",
|
||||||
type: "Chien",
|
|
||||||
avant: "../../img/avant1.jpg",
|
|
||||||
apres: "../../img/apres1.jpg"
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 2,
|
id: 2,
|
||||||
titre: "Coupe ciseaux",
|
titre: "Coupe ciseaux",
|
||||||
type: "Chat",
|
|
||||||
avant: "../../img/avant2.jpg",
|
|
||||||
apres: "../../img/apres2.jpg"
|
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -41,33 +39,21 @@ function displayPairs() {
|
|||||||
|
|
||||||
row.innerHTML = `
|
row.innerHTML = `
|
||||||
<td>${pair.titre}</td>
|
<td>${pair.titre}</td>
|
||||||
<td>${pair.type}</td>
|
|
||||||
|
|
||||||
<td>
|
|
||||||
<img src="${pair.avant}" class="img-thumbnail" style="max-width: 80px;">
|
|
||||||
</td>
|
|
||||||
|
|
||||||
<td>
|
|
||||||
<img src="${pair.apres}" class="img-thumbnail" style="max-width: 80px;">
|
|
||||||
</td>
|
|
||||||
|
|
||||||
<td class="text-center text-md-start">
|
<td class="text-center text-md-start">
|
||||||
<div class="d-flex flex-column flex-md-row justify-content-center justify-content-md-start gap-2">
|
<div class="d-flex flex-column flex-md-row justify-content-center justify-content-md-end gap-2">
|
||||||
|
|
||||||
<!-- Bouton Voir -->
|
|
||||||
<a href="../html/voir_avant_apres.html?id=${pair.id}"
|
|
||||||
class="btn btn-info btn-sm">
|
|
||||||
Voir
|
|
||||||
</a>
|
|
||||||
|
|
||||||
<!-- Bouton Modifier -->
|
<!-- Bouton Modifier -->
|
||||||
<a href="../html/modifier_avant_apres.html?id=${pair.id}"
|
<a href="../html/modifier_avant_apres.html?id=${pair.id}"
|
||||||
class="btn btn-warning btn-sm">
|
class="btn btn-outline-primary btn-sm">
|
||||||
Modifier
|
Modifier
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<!-- Bouton Supprimer -->
|
<!-- Bouton Supprimer -->
|
||||||
<button class="btn btn-danger btn-sm" onclick="openDeleteModal(${pair.id})">
|
<button class="btn btn-outline-danger btn-sm" onclick="openDeleteModal(${pair.id})">
|
||||||
Supprimer
|
Supprimer
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user