Compare commits
32 Commits
baf730af3e
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 63592a114d | |||
| 74a04ea355 | |||
| 5b0edbccca | |||
| ad9e8b8308 | |||
| fc19007b05 | |||
| efad1b078e | |||
| 16ab4707e2 | |||
| 84d8f1c481 | |||
| 9e80b99abe | |||
| 2125bfb126 | |||
| a0e14bfa92 | |||
| e2fe18ec04 | |||
| 8fe2e99953 | |||
| 417ff38b59 | |||
| aa5f003be8 | |||
| 8867ae1b06 | |||
| 2923a9eb52 | |||
| 50b3904af6 | |||
| 7fc3e350d0 | |||
| 5297dcbcc3 | |||
| 37b1d7ede5 | |||
| 77310c974e | |||
| e04e29bf48 | |||
| bf25a80f43 | |||
| 7fb728fc00 | |||
| 33b0c0cab8 | |||
| 9a8891fc9d | |||
| 4f85fe3250 | |||
| a2ecb6bf84 | |||
| f79ee1e7b6 | |||
| f0fbae505f | |||
| 6b2b45fc6a |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
node_modules/
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Ajouter une catégorie</title>
|
|
||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
|
||||||
|
|
||||||
<style>
|
|
||||||
body{
|
|
||||||
background: #f4f6f981;
|
|
||||||
|
|
||||||
}
|
|
||||||
.container{
|
|
||||||
max-width: 600px;
|
|
||||||
margin-top: 50px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
<h2 class="mb-5 text-center">Ajouter une catégorie</h2>
|
|
||||||
|
|
||||||
<!--Erreur champ vide -->
|
|
||||||
<div id="errorEmpty" class="alert alert-danger d-none">Le nom de catégorie est obligatoire.</div>
|
|
||||||
|
|
||||||
<!--Erreur nom deja existant -->
|
|
||||||
<div id="errorExists" class="alert alert-danger d-none">Cette catégorie existe déjà. Veuillez en choisir une autre.</div>
|
|
||||||
|
|
||||||
<!--Succès ajout catégorie -->
|
|
||||||
<div id="successMessage" class="alert alert-success d-none">Catégorie ajoutée avec succès !</div>
|
|
||||||
|
|
||||||
<form id="addCategoryForm">
|
|
||||||
|
|
||||||
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold">Nom de la catégorie (obligatoire)</label>
|
|
||||||
<input type="text" id="categoryName" class="form-control" placeholder="Actualité, chien, chat .." required></div>
|
|
||||||
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold">Description</label>
|
|
||||||
<textarea id="categoryDescription" class="form-control" rows="4" placeholder="Entrez une description (optionnel)"></textarea>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="d-flex gap-3 mt-4">
|
|
||||||
<a href="liste_categories.html" class="btn btn-secondary w-50">Annuler</a>
|
|
||||||
<button type="submit" class="btn btn-primary w-50">Ajouter</button>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="ajouter.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,104 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Ajouter un article</title>
|
|
||||||
<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>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
background: #f4f6f9;
|
|
||||||
}
|
|
||||||
.container {
|
|
||||||
max-width: 700px;
|
|
||||||
margin: 40px auto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
<h2 class="mb-5 text-center">Ajouter un article</h2>
|
|
||||||
<form id="ajouterArticleForm" action="../../../blog/categories/articles/liste_article.html" method="GET">
|
|
||||||
|
|
||||||
|
|
||||||
<!--Erreur titre vide-->
|
|
||||||
<div id="errorEmpty" class="alert alert-danger d-none">Le titre de l'article est obligatoire</div>
|
|
||||||
|
|
||||||
<!--Erreur image invalide-->
|
|
||||||
<div id="errorImage" class="alert alert-danger d-none">
|
|
||||||
Format d'image invalide. Formats acceptés : JPG, PNG
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Erreur titre existant-->
|
|
||||||
<div id="errorExists" class="alert alert-danger d-none">Ce titre existe déjà. Choisissez un autre titre.</div>
|
|
||||||
|
|
||||||
<!--Succès ajout article-->
|
|
||||||
<div id="successMsg" class="alert alert-success d-none">Article ajouté avec succès !</div>
|
|
||||||
|
|
||||||
<!--Catégorie-->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold">Catégorie de l'article</label>
|
|
||||||
<input list="categories" id="articleCategory" class="form-control" placeholder="Entrez une catégorie">
|
|
||||||
|
|
||||||
<datalist id="categories">
|
|
||||||
<option value="actualités">
|
|
||||||
<option value="chien">
|
|
||||||
<option value="chat">
|
|
||||||
<option value="boutique">
|
|
||||||
</datalist>
|
|
||||||
|
|
||||||
|
|
||||||
<!--Titre-->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold">Titre de l'article (obligatoire)</label>
|
|
||||||
<input type="text" id="articleTitle" class="form-control" placeholder="Entrez le titre de l'article">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Contenu-->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold">Contenu de l'article</label>
|
|
||||||
<textarea id="articleContent" class="form-control" rows="5" placeholder="Entrez le contenu de l'article"></textarea>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Image-->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold">Image de l'article</label>
|
|
||||||
<input type="file" id="articleImage" class="form-control" accept="image/*">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Publié-->
|
|
||||||
<div class="form-check mb-3">
|
|
||||||
<input class="form-check-input" type="checkbox" id="articlePublished">
|
|
||||||
<label class="form-check-label" for="articlePublished">Publié</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<!--Boutons-->
|
|
||||||
<div class="d-flex gap-3 mt-4">
|
|
||||||
<a href="../../../blog/categories/articles/liste_article.html" class="btn btn-secondary w-50">Annuler</a>
|
|
||||||
<button type="submit" class="btn btn-primary w-50">Ajouter</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="ajouter_article.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
<script>
|
|
||||||
ClassicEditor
|
|
||||||
.create(document.querySelector('#articleContent'))
|
|
||||||
.catch(error => {
|
|
||||||
console.error(error);
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
const form = document.getElementById('addArticleForm');
|
|
||||||
const imgField = document.getElementById('articleImage');
|
|
||||||
const titleField = document.getElementById('articleTitle');
|
|
||||||
const contentField = document.getElementById('articleContent');
|
|
||||||
const categoryField = document.getElementById('articleCategory');
|
|
||||||
const publishedField = document.getElementById('articlePublished');
|
|
||||||
|
|
||||||
const errorEmpty = document.getElementById('errorEmpty');
|
|
||||||
const errorImage = document.getElementById('errorImage');
|
|
||||||
const errorExists = document.getElementById('errorExists');
|
|
||||||
const successMsg = document.getElementById('successMsg');
|
|
||||||
|
|
||||||
// Simulation BDD
|
|
||||||
const titreExistants = ['décoration noel', 'coupe de chien'];
|
|
||||||
|
|
||||||
form.addEventListener('submit', function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
|
|
||||||
const titre = titleField.value.trim() .toLowerCase();
|
|
||||||
const fichierImage = imgField.files[0];
|
|
||||||
|
|
||||||
// Reset messages
|
|
||||||
errorEmpty.classList.add('d-none');
|
|
||||||
errorImage.classList.add('d-none');
|
|
||||||
errorExists.classList.add('d-none');
|
|
||||||
successMsg.classList.add('d-none');
|
|
||||||
|
|
||||||
// Titre obligatoire
|
|
||||||
if (titre === "") {
|
|
||||||
errorEmpty.classList.remove('d-none');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Titre déjà existant
|
|
||||||
if (titreExistants.includes(titre)) {
|
|
||||||
errorExists.classList.remove('d-none');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Image invalide
|
|
||||||
if (fichierImage) {
|
|
||||||
const validFormats = ['image/jpeg', 'image/png'];
|
|
||||||
if (!validFormats.includes(fichierImage.type)) {
|
|
||||||
errorImage.classList.remove('d-none');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Simuler enregistrement
|
|
||||||
titreExistants.push(titre);
|
|
||||||
|
|
||||||
});
|
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Liste des article</title>
|
|
||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
|
||||||
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
background: #f4f6f9;
|
|
||||||
}
|
|
||||||
.container {
|
|
||||||
margin-top: 60px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
<div class="d-flex justify-content-between align-items-center mb-4">
|
|
||||||
<h2 class="mb-0">Listes des articles</h2>
|
|
||||||
<a href="ajouter_article.html" class="btn btn-primary">Ajouter un article</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<table class="table table-bordered table-hover bg-white">
|
|
||||||
<thead class="table-light">
|
|
||||||
<tr>
|
|
||||||
<th>Titre</th>
|
|
||||||
<th>Catégorie</th>
|
|
||||||
<th>Publié</th>
|
|
||||||
<th>Actions</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tbody>
|
|
||||||
<!--Exemple d'article-->
|
|
||||||
<tr>
|
|
||||||
<td>Mon premier article</td>
|
|
||||||
<td>Chien</td>
|
|
||||||
<td>Oui</td>
|
|
||||||
<td>
|
|
||||||
<a href="voir_article.html" class="btn btn-sm btn-outline-secondary">Voir</a>
|
|
||||||
<a href="modifier_article.html" class="btn btn-sm btn-outline-primary">Modifier</a>
|
|
||||||
<button class="btn btn-sm btn-outline-danger" onclick="confirmerSuppression('Mon premier article')">Supprimer</button>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
function confirmerSuppression(titre) {
|
|
||||||
const confirmation = confirm(`Êtes-vous sûr de vouloir supprimer l'article "${titre}" ?`);
|
|
||||||
if (confirmation) {
|
|
||||||
alert(`L'article "${titre}" a été supprimé.`);
|
|
||||||
// Ici tu peux rediriger ou supprimer réellement
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,145 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Modifier un article</title>
|
|
||||||
<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>
|
|
||||||
|
|
||||||
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
background: #f4f6f9;
|
|
||||||
}
|
|
||||||
.container {
|
|
||||||
max-width: 700px;
|
|
||||||
margin-top: 40px;
|
|
||||||
}
|
|
||||||
.preview-img {
|
|
||||||
max-width: 15Opx;
|
|
||||||
border-radius: 8px
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
<h2 class="mb-4 text-center">Modifier un article</h2>
|
|
||||||
|
|
||||||
<!--Erreur titre vide-->
|
|
||||||
<div id="errorEmpty" class="alert alert-danger d-none">
|
|
||||||
g Le titre de l'article est obligatoire.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Erreur image invalide-->
|
|
||||||
<div id="errorImage" class="alert alert-danger d-none">
|
|
||||||
Format d'image invalide. Formats acceptés : JPG, PNG, GIF.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Erreur titre existant-->
|
|
||||||
<div id="errorExists" class="alert alert-danger d-none">
|
|
||||||
Ce titre existe déjà. Veuillez en choisir un autre.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Succès-->
|
|
||||||
<div id="successMsg" class="alert alert-success d-none">
|
|
||||||
L'article a été modifié avec succès !
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Formulaire -->
|
|
||||||
<form id="editArticleForm">
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!--Titre-->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold">Titre de l'article (obligatoire)</label>
|
|
||||||
<input type="text" id="articleTitle" class="form-control" value="Titre de l'article actuel" placeholder="Modifier le titre">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Contenu-->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold">Contenu de l'article</label>
|
|
||||||
<textarea id="articleContent" class="form-control" rows="5">Contenu de l'article actuel...</textarea>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Catégorie-->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold">Catégorie de l'article</label>
|
|
||||||
<input
|
|
||||||
type="text"
|
|
||||||
id="articleCategory"
|
|
||||||
class="form-control"
|
|
||||||
list="categories"
|
|
||||||
placeholder="Entrez une catégorie">
|
|
||||||
|
|
||||||
<datalist id="categories">
|
|
||||||
<option value="actualités">
|
|
||||||
<option value="chien">
|
|
||||||
<option value="chat">
|
|
||||||
<option value="boutique">
|
|
||||||
</datalist>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image actuelle -->
|
|
||||||
<label class="fw-bold">Image actuelle</label>
|
|
||||||
<div class="mb-4">
|
|
||||||
<img src="/blog/categories/images/article1.jpg" alt="Image actuelle" class="preview-img mb-2">
|
|
||||||
<input type="file" id="articleImage" class="form-control" accept="image/*">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Publié-->
|
|
||||||
<div class="form-check mb-3">
|
|
||||||
<input class="form-check-input" type="checkbox" id="articlePublished" checked>
|
|
||||||
<label class="form-check-label">Publié</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!--Boutons-->
|
|
||||||
<div class="d-flex gap-3 mt-4">
|
|
||||||
<a href="../../../blog/categories/articles/liste_article.html" class="btn btn-secondary w-50">Annuler</a>
|
|
||||||
<button type="submit" class="btn btn-primary w-50">Enregistrer</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</form>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
ClassicEditor
|
|
||||||
.create(document.querySelector('#articleContent'))
|
|
||||||
.catch(error => {
|
|
||||||
console.error(error);
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script src="modifier_article.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,68 +0,0 @@
|
|||||||
const form = document.getElementById('editArticleForm');
|
|
||||||
const imgField = document.getElementById('articleImage');
|
|
||||||
const titleField = document.getElementById('articleTitle');
|
|
||||||
const contentField = document.getElementById('articleContent');
|
|
||||||
const categoryField = document.getElementById('articleCategory');
|
|
||||||
const publishedField = document.getElementById('articlePublished');
|
|
||||||
|
|
||||||
const errorEmpty = document.getElementById('errorEmpty');
|
|
||||||
const errorImage = document.getElementById('errorImage');
|
|
||||||
const errorExists = document.getElementById('errorExists');
|
|
||||||
const successMsg = document.getElementById('successMsg');
|
|
||||||
|
|
||||||
// Simulation BDD pour vérifier doublons
|
|
||||||
const titresExistants = [
|
|
||||||
"article de test",
|
|
||||||
"nouveautés chiens",
|
|
||||||
"actualité du mois"
|
|
||||||
];
|
|
||||||
|
|
||||||
form.addEventListener('submit', function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
|
|
||||||
const titre = titleField.value.trim().toLowerCase();
|
|
||||||
const fichierImage = imgField.files[0];
|
|
||||||
|
|
||||||
// Reset messages
|
|
||||||
errorEmpty.classList.add('d-none');
|
|
||||||
errorImage.classList.add('d-none');
|
|
||||||
errorExists.classList.add('d-none');
|
|
||||||
successMsg.classList.add('d-none');
|
|
||||||
|
|
||||||
//Titre obligatoire
|
|
||||||
if (titre === "") {
|
|
||||||
errorEmpty.classList.remove('d-none');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Titre déjà existant ?
|
|
||||||
if (titresExistants.includes(titre)) {
|
|
||||||
errorExists.classList.remove('d-none');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Vérification image
|
|
||||||
if (fichierImage) {
|
|
||||||
const validFormats = ['image/jpeg', 'image/png', 'image/gif'];
|
|
||||||
if (!validFormats.includes(fichierImage.type)) {
|
|
||||||
errorImage.classList.remove('d-none');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Succès
|
|
||||||
successMsg.classList.remove('d-none');
|
|
||||||
|
|
||||||
console.log("Article modifié :", {
|
|
||||||
titre,
|
|
||||||
contenu: contentField.value,
|
|
||||||
categorie: categoryField.value,
|
|
||||||
publie: publishedField.checked,
|
|
||||||
image: fichierImage ? fichierImage.name : "Image inchangée"
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Modifier une catégorie</title>
|
|
||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
|
||||||
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
background: #f4f6f981;
|
|
||||||
|
|
||||||
}
|
|
||||||
.container {
|
|
||||||
max-width: 600px;
|
|
||||||
margin: 50px auto;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
<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">
|
|
||||||
|
|
||||||
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label fw-bold">Nom de la catégorie (obligatoire)</label>
|
|
||||||
<input type="text" id="categoryName" class="form-control" placeholder="Entrez le nom de la catégorie" required>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label fw-bold">Description (optionnel)</label>
|
|
||||||
<textarea id="categorieDescription" class="form-control" rows="4" placeholder="Entrez une description" required></textarea>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="d-flex gap-3 mt-4">
|
|
||||||
<a href="liste_categories.html" class="btn btn-secondary w-50">Annuler</a>
|
|
||||||
<button type="submit" class="btn btn-primary w-50">Enregistrer</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
|
|
||||||
const form = document.getElementById("modifierCategorie");
|
|
||||||
const nameField = document.getElementById("categoryName");
|
|
||||||
const descField = document.getElementById("categorieDescription");
|
|
||||||
const errorMsg = document.getElementById("errorMsg");
|
|
||||||
const successMsg = document.getElementById("successMsg");
|
|
||||||
|
|
||||||
form.addEventListener("submit", function (e) {
|
|
||||||
e.preventDefault();
|
|
||||||
|
|
||||||
//vérification des champs obligatoires
|
|
||||||
if (nameField.value.trim() === "" || descField.value.trim() === "") {
|
|
||||||
errorMsg.classList.remove("d-none");
|
|
||||||
successMsg.classList.add("d-none");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Succès
|
|
||||||
errorMsg.classList.add("d-none");
|
|
||||||
successMsg.classList.remove("d-none");
|
|
||||||
|
|
||||||
});
|
|
||||||
163
blog/html/accueil_blog.html
Normal file
163
blog/html/accueil_blog.html
Normal file
@@ -0,0 +1,163 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Admin |Modifier le blog</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">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</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 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>
|
||||||
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
|
<header>
|
||||||
|
<h1 class="title fs-2">Modifier la page blog</h1>
|
||||||
|
</header>
|
||||||
|
<main>
|
||||||
|
|
||||||
|
|
||||||
|
<section class="mb-5 section-categories">
|
||||||
|
<h2 class="my-4 fs-3">Liste des catégories</h2>
|
||||||
|
|
||||||
|
<!-- Message succès catégories -->
|
||||||
|
<div id="successCategoriesMsg" class="alert alert-success d-none"></div>
|
||||||
|
|
||||||
|
<!-- Bouton ajouter catégorie -->
|
||||||
|
<div class="d-flex justify-content-start mb-4">
|
||||||
|
<a href="ajouter_categorie.html" class="btn btn-primary">Ajouter une catégorie</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Tableau catégories -->
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Nom</th>
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody id="categoriesTableBody">
|
||||||
|
<!-- rempli en JS -->
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<section class="section-articles">
|
||||||
|
<h2 class="my-4 fs-3">Liste des articles</h2>
|
||||||
|
|
||||||
|
<!-- Message succès articles -->
|
||||||
|
<div id="successArticlesMsg" class="alert alert-success d-none"></div>
|
||||||
|
|
||||||
|
<!-- Bouton ajouter article -->
|
||||||
|
<div class="d-flex justify-content-start mb-4">
|
||||||
|
<a href="ajouter_article.html" class="btn btn-primary">Ajouter un article</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Tableau articles -->
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead class="table-dark">
|
||||||
|
<tr>
|
||||||
|
<th>Titre</th>
|
||||||
|
<th class="text-end">Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
|
||||||
|
<tbody id="articlesTableBody">
|
||||||
|
<tr>
|
||||||
|
<td>Mon premier article</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="modifier_article.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>Mon deuxième article</td>
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="modifier_article.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>
|
||||||
|
</section>
|
||||||
|
</main>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
<script src="../js/liste_categorie.js"></script>
|
||||||
|
<script src="../js/liste_articles.js"></script>
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</body>
|
||||||
166
blog/html/ajouter_article.html
Normal file
166
blog/html/ajouter_article.html
Normal file
@@ -0,0 +1,166 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Ajouter un article</title>
|
||||||
|
<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/translations/fr.js"></script>
|
||||||
|
<link rel="stylesheet" href="../../css/blog.css">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<style>
|
||||||
|
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<!-- HEADER -->
|
||||||
|
<header>
|
||||||
|
<nav class="navbar navbar-expand-xxl bg-body-tertiary shadow-sm">
|
||||||
|
<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">
|
||||||
|
|
||||||
|
<!-- MENU GAUCHE -->
|
||||||
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
||||||
|
<li class="nav-item"><a class="nav-link active" href="#">Blog</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Boutique</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Prestations</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">FAQ</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Fiche de renseignements</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Partenaires</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<!-- MENU DROIT -->
|
||||||
|
<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" data-bs-toggle="dropdown">
|
||||||
|
<i class="bi bi-person-circle me-1"></i> <span id="userFirstName">Prénom</span>
|
||||||
|
</a>
|
||||||
|
<ul class="dropdown-menu dropdown-menu-end">
|
||||||
|
<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>
|
||||||
|
|
||||||
|
<div class="container">
|
||||||
|
<h2 class="mb-5 text-center">Ajouter un article</h2>
|
||||||
|
<form id="ajouterArticleForm">
|
||||||
|
|
||||||
|
|
||||||
|
<!--Erreur titre vide-->
|
||||||
|
<div id="errorEmpty" class="alert alert-danger d-none">Le titre de l'article est obligatoire</div>
|
||||||
|
|
||||||
|
<!--Erreur image invalide-->
|
||||||
|
<div id="errorImage" class="alert alert-danger d-none">
|
||||||
|
Format d'image invalide. Formats acceptés : JPG, PNG
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Erreur titre existant-->
|
||||||
|
<div id="errorExists" class="alert alert-danger d-none">Ce titre existe déjà. Choisissez un autre titre.</div>
|
||||||
|
|
||||||
|
<!--Succès ajout article-->
|
||||||
|
<div id="successMsg" class="alert alert-success d-none">Article ajouté avec succès !</div>
|
||||||
|
|
||||||
|
<!-- Catégorie -->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold">Catégorie de l'article (obligatoire)</label>
|
||||||
|
<select id="articleCategory" class="form-select" required>
|
||||||
|
<option value="" disabled selected>Choisissez une catégorie</option>
|
||||||
|
<option value="actualités">Actualités</option>
|
||||||
|
<option value="chien">Chien</option>
|
||||||
|
<option value="chat">Chat</option>
|
||||||
|
<option value="boutique">Boutique</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Titre -->
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold">Titre de l'article (obligatoire)</label>
|
||||||
|
<input type="text" id="articleTitle" class="form-control" placeholder="Entrez le titre de l'article">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Contenu -->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold">Contenu de l'article</label>
|
||||||
|
<textarea id="articleContent" class="form-control" rows="5" placeholder="Entrez le contenu de l'article"></textarea>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Image -->
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold">Image de l'article</label>
|
||||||
|
<input type="file" id="articleImage" class="form-control" accept="image/*">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!--Publié-->
|
||||||
|
<div class="form-check mb-3">
|
||||||
|
<input class="form-check-input" type="checkbox" id="articlePublished">
|
||||||
|
<label class="form-check-label" for="articlePublished">Publié (sera publié sur le facebook)</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<!--Boutons-->
|
||||||
|
<div class="d-flex gap-3 mt-4">
|
||||||
|
<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>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="../js/ajouter_article.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>
|
||||||
|
tinymce.init({
|
||||||
|
selector: '#articleContent',
|
||||||
|
height: 400,
|
||||||
|
language: 'fr',
|
||||||
|
plugins: 'lists fullscreen',
|
||||||
|
toolbar: 'undo redo | bold italic underline | bullist numlist | fullscreen'
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
110
blog/html/ajouter_categorie.html
Normal file
110
blog/html/ajouter_categorie.html
Normal file
@@ -0,0 +1,110 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Ajouter une catégorie</title>
|
||||||
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css">
|
||||||
|
|
||||||
|
<style>
|
||||||
|
body{
|
||||||
|
background: #f4f6f981;
|
||||||
|
|
||||||
|
}
|
||||||
|
.container{
|
||||||
|
|
||||||
|
margin-top: 50px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<!-- HEADER -->
|
||||||
|
<header>
|
||||||
|
<nav class="navbar navbar-expand-xxl bg-body-tertiary shadow-sm">
|
||||||
|
<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">
|
||||||
|
|
||||||
|
<!-- MENU GAUCHE -->
|
||||||
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
||||||
|
<li class="nav-item"><a class="nav-link active" href="#">Blog</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Boutique</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Prestations</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">FAQ</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Fiche de renseignements</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Partenaires</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<!-- MENU DROIT -->
|
||||||
|
<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" data-bs-toggle="dropdown">
|
||||||
|
<i class="bi bi-person-circle me-1"></i> <span id="userFirstName">Prénom</span>
|
||||||
|
</a>
|
||||||
|
<ul class="dropdown-menu dropdown-menu-end">
|
||||||
|
<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>
|
||||||
|
|
||||||
|
<div class="container">
|
||||||
|
<h2 class="mb-5 text-center">Ajouter une catégorie</h2>
|
||||||
|
|
||||||
|
<!--Erreur champ vide -->
|
||||||
|
<div id="errorEmpty" class="alert alert-danger d-none">Le nom de catégorie est obligatoire.</div>
|
||||||
|
|
||||||
|
<!--Erreur nom deja existant -->
|
||||||
|
<div id="errorExists" class="alert alert-danger d-none">Cette catégorie existe déjà. Veuillez en choisir une autre.</div>
|
||||||
|
|
||||||
|
<!--Succès ajout catégorie -->
|
||||||
|
<div id="successMessage" class="alert alert-success d-none">Catégorie ajoutée avec succès !</div>
|
||||||
|
|
||||||
|
<form id="addCategoryForm">
|
||||||
|
|
||||||
|
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold">Nom de la catégorie (obligatoire)</label>
|
||||||
|
<input type="text" id="categoryName" class="form-control" placeholder="Actualité, chien, chat .." required></div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold">Description</label>
|
||||||
|
<textarea id="categoryDescription" class="form-control" rows="4" placeholder="Entrez une description (optionnel)"></textarea>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="d-flex gap-3 mt-4">
|
||||||
|
<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>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="../js/ajouter_categorie.js"></script>
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
188
blog/html/modifier_article.html
Normal file
188
blog/html/modifier_article.html
Normal file
@@ -0,0 +1,188 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Modifier un article</title>
|
||||||
|
<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/translations/fr.js"></script>
|
||||||
|
|
||||||
|
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background: #f4f6f9;
|
||||||
|
}
|
||||||
|
.container {
|
||||||
|
|
||||||
|
margin-top: 40px;
|
||||||
|
}
|
||||||
|
.preview-img {
|
||||||
|
max-width: 15px;
|
||||||
|
border-radius: 8px
|
||||||
|
}
|
||||||
|
.ck-editor__editable {
|
||||||
|
min-height: 350px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<!-- HEADER -->
|
||||||
|
<header>
|
||||||
|
<nav class="navbar navbar-expand-xxl bg-body-tertiary shadow-sm">
|
||||||
|
<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">
|
||||||
|
|
||||||
|
<!-- MENU GAUCHE -->
|
||||||
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
||||||
|
<li class="nav-item"><a class="nav-link active" href="#">Blog</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Boutique</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Prestations</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">FAQ</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Fiche de renseignements</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Partenaires</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<!-- MENU DROIT -->
|
||||||
|
<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" data-bs-toggle="dropdown">
|
||||||
|
<i class="bi bi-person-circle me-1"></i> <span id="userFirstName">Prénom</span>
|
||||||
|
</a>
|
||||||
|
<ul class="dropdown-menu dropdown-menu-end">
|
||||||
|
<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>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="container">
|
||||||
|
<h2 class="mb-4 text-center">Modifier un article</h2>
|
||||||
|
|
||||||
|
<!--Erreur titre vide-->
|
||||||
|
<div id="errorEmpty" class="alert alert-danger d-none">
|
||||||
|
g Le titre de l'article est obligatoire.
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Erreur image invalide-->
|
||||||
|
<div id="errorImage" class="alert alert-danger d-none">
|
||||||
|
Format d'image invalide. Formats acceptés : JPG, PNG, GIF.
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Erreur titre existant-->
|
||||||
|
<div id="errorExists" class="alert alert-danger d-none">
|
||||||
|
Ce titre existe déjà. Veuillez en choisir un autre.
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Succès-->
|
||||||
|
<div id="successMsg" class="alert alert-success d-none">
|
||||||
|
L'article a été modifié avec succès !
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Formulaire -->
|
||||||
|
<form id="editArticleForm">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!--Titre-->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold">Titre de l'article (obligatoire)</label>
|
||||||
|
<input type="text" id="articleTitle" class="form-control" value="Titre de l'article actuel" placeholder="Modifier le titre">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Contenu-->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold">Contenu de l'article</label>
|
||||||
|
<textarea id="articleContent" class="form-control" rows="5">Contenu de l'article actuel...</textarea>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Catégorie-->
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold">Catégorie de l'article</label>
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
id="articleCategory"
|
||||||
|
class="form-control"
|
||||||
|
list="categories"
|
||||||
|
placeholder="Entrez une catégorie">
|
||||||
|
|
||||||
|
<datalist id="categories">
|
||||||
|
<option value="actualités">
|
||||||
|
<option value="chien">
|
||||||
|
<option value="chat">
|
||||||
|
<option value="boutique">
|
||||||
|
</datalist>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Image actuelle -->
|
||||||
|
<label class="fw-bold">Image actuelle</label>
|
||||||
|
<div class="mb-4">
|
||||||
|
<img src="/blog/categories/images/article1.jpg" alt="Image actuelle" class="preview-img mb-2">
|
||||||
|
<input type="file" id="articleImage" class="form-control" accept="image/*">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Publié-->
|
||||||
|
<div class="form-check mb-3">
|
||||||
|
<input class="form-check-input" type="checkbox" id="articlePublished" checked>
|
||||||
|
<label class="form-check-label">Publié (sera publié sur facebook)</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--Boutons-->
|
||||||
|
<div class="d-flex gap-3 mt-4">
|
||||||
|
<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>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
ClassicEditor
|
||||||
|
.create(document.querySelector('#articleContent'), {
|
||||||
|
language: 'fr',
|
||||||
|
toolbar: [
|
||||||
|
'heading',
|
||||||
|
'bold', 'italic', 'underline',
|
||||||
|
'bulletedList', 'numberedList',
|
||||||
|
'undo', 'redo'
|
||||||
|
]
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<script src="../js/modifier_article.js"></script>
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
100
blog/html/modifier_categorie.html
Normal file
100
blog/html/modifier_categorie.html
Normal file
@@ -0,0 +1,100 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<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="../../css/blog.css">
|
||||||
|
|
||||||
|
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
|
||||||
|
<!-- HEADER -->
|
||||||
|
<header>
|
||||||
|
<nav class="navbar navbar-expand-xxl bg-body-tertiary shadow-sm">
|
||||||
|
<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">
|
||||||
|
|
||||||
|
<!-- MENU GAUCHE -->
|
||||||
|
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
|
||||||
|
<li class="nav-item"><a class="nav-link active" href="#">Blog</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Boutique</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Prestations</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">FAQ</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Fiche de renseignements</a></li>
|
||||||
|
<li class="nav-item"><a class="nav-link" href="#">Partenaires</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<!-- MENU DROIT -->
|
||||||
|
<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" data-bs-toggle="dropdown">
|
||||||
|
<i class="bi bi-person-circle me-1"></i> <span id="userFirstName">Prénom</span>
|
||||||
|
</a>
|
||||||
|
<ul class="dropdown-menu dropdown-menu-end">
|
||||||
|
<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>
|
||||||
|
|
||||||
|
<div class="container">
|
||||||
|
<h2 class="mb-5 text-center">Modifier une catégorie</h2>
|
||||||
|
|
||||||
|
|
||||||
|
<form id="modifierCategorie">
|
||||||
|
|
||||||
|
|
||||||
|
<div class="mb-4">
|
||||||
|
<label class="form-label fw-bold">Nom de la catégorie (obligatoire)</label>
|
||||||
|
<input type="text" id="categoryName" class="form-control" placeholder="Entrez le nom de la catégorie" required>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label fw-bold">Description (optionnel)</label>
|
||||||
|
<textarea id="categorieDescription" class="form-control" rows="4" placeholder="Entrez une description" required></textarea>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="d-flex gap-3 mt-4">
|
||||||
|
<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>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="../js/modifier_categorie.js"></script>
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
106
blog/js/ajouter_article.js
Normal file
106
blog/js/ajouter_article.js
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
const form = document.getElementById('ajouterArticleForm');
|
||||||
|
const imgField = document.getElementById('articleImage');
|
||||||
|
const titleField = document.getElementById('articleTitle');
|
||||||
|
const categoryField = document.getElementById('articleCategory');
|
||||||
|
const publishedField = document.getElementById('articlePublished');
|
||||||
|
|
||||||
|
const errorEmpty = document.getElementById('errorEmpty');
|
||||||
|
const errorImage = document.getElementById('errorImage');
|
||||||
|
const errorExists = document.getElementById('errorExists');
|
||||||
|
const successMsg = document.getElementById('successMsg');
|
||||||
|
|
||||||
|
// Simulation BDD
|
||||||
|
const titreExistants = ['décoration noel', 'coupe de chien'];
|
||||||
|
|
||||||
|
form.addEventListener('submit', function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
const titre = titleField.value.trim().toLowerCase();
|
||||||
|
const fichierImage = imgField.files[0];
|
||||||
|
const contenu = tinymce.get("articleContent").getContent();
|
||||||
|
const categorie = categoryField.value;
|
||||||
|
const published = publishedField.checked; // récupère la case cochée
|
||||||
|
|
||||||
|
// Reset messages
|
||||||
|
errorEmpty.classList.add('d-none');
|
||||||
|
errorImage.classList.add('d-none');
|
||||||
|
errorExists.classList.add('d-none');
|
||||||
|
successMsg.classList.add('d-none');
|
||||||
|
|
||||||
|
// Catégorie obligatoire
|
||||||
|
if (categorie === "") {
|
||||||
|
errorEmpty.textContent = "Veuillez choisir une catégorie.";
|
||||||
|
errorEmpty.classList.remove('d-none');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Titre obligatoire
|
||||||
|
if (titre === "") {
|
||||||
|
errorEmpty.textContent = "Le titre de l'article est obligatoire.";
|
||||||
|
errorEmpty.classList.remove('d-none');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Titre déjà existant
|
||||||
|
if (titreExistants.includes(titre)) {
|
||||||
|
errorExists.classList.remove('d-none');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Contenu obligatoire
|
||||||
|
if (contenu.trim() === "") {
|
||||||
|
errorEmpty.textContent = "Le contenu de l'article ne peut pas être vide.";
|
||||||
|
errorEmpty.classList.remove('d-none');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Image invalide
|
||||||
|
if (fichierImage) {
|
||||||
|
const validFormats = ['image/jpeg', 'image/png'];
|
||||||
|
if (!validFormats.includes(fichierImage.type)) {
|
||||||
|
errorImage.classList.remove('d-none');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Simuler enregistrement
|
||||||
|
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
|
||||||
|
successMsg.classList.remove('d-none');
|
||||||
|
|
||||||
|
// Redirection
|
||||||
|
setTimeout(() => {
|
||||||
|
window.location.href = "../html/accueil_blog.html";
|
||||||
|
}, 1000);
|
||||||
|
});
|
||||||
|
|
||||||
|
// TinyMCE INIT
|
||||||
|
tinymce.init({
|
||||||
|
selector: '#articleContent',
|
||||||
|
height: 400,
|
||||||
|
language: 'fr',
|
||||||
|
plugins: 'lists fullscreen',
|
||||||
|
toolbar: 'undo redo | bold italic underline | bullist numlist | fullscreen'
|
||||||
|
});
|
||||||
@@ -35,8 +35,13 @@ form.addEventListener("submit", function (e) {
|
|||||||
// Succès
|
// Succès
|
||||||
successMessage.classList.remove("d-none");
|
successMessage.classList.remove("d-none");
|
||||||
|
|
||||||
|
// Ajout d'une nouvelle catégorie
|
||||||
|
existingCategories.push(nom);
|
||||||
|
|
||||||
|
// Redirection après 1 seconde
|
||||||
|
setTimeout(() => {
|
||||||
|
window.location.href = "../html/accueil_blog.html";
|
||||||
|
}, 1000);
|
||||||
|
|
||||||
//Ajout d'une nouvelle catégorie en BDD
|
|
||||||
categoriesExistantes.push(nom);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
67
blog/js/liste_articles.js
Normal file
67
blog/js/liste_articles.js
Normal file
@@ -0,0 +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) {
|
||||||
|
const btn = e.target.closest(".delete-btn");
|
||||||
|
if (!btn) return;
|
||||||
|
|
||||||
|
const row = btn.closest("tr");
|
||||||
|
const titre = row.querySelector("td").textContent.trim();
|
||||||
|
const id = Number(btn.dataset.id);
|
||||||
|
|
||||||
|
if (confirm(`Voulez-vous vraiment supprimer l'article : "${titre}" ?`)) {
|
||||||
|
|
||||||
|
// 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é !");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Lancer l'affichage dès que la page charge
|
||||||
|
afficherArticles();
|
||||||
53
blog/js/liste_categorie.js
Normal file
53
blog/js/liste_categorie.js
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
// Simulation BDD
|
||||||
|
let categories = [
|
||||||
|
{ id: 1, nom: "Actualités", description: "Infos et nouveautés" },
|
||||||
|
{ id: 2, nom: "Chien", description: "Articles liés aux chiens" },
|
||||||
|
{ id: 3, nom: "Chat", description: "Conseils pour chats" },
|
||||||
|
{ id: 4, nom: "Boutique", description: "Produits et accessoires" }
|
||||||
|
];
|
||||||
|
|
||||||
|
const tableBody = document.getElementById("categoriesTableBody");
|
||||||
|
const successMsg = document.getElementById("successMsg");
|
||||||
|
|
||||||
|
// Fonction d'affichage
|
||||||
|
function afficherCategories() {
|
||||||
|
tableBody.innerHTML = "";
|
||||||
|
|
||||||
|
categories.forEach((cat, index) => {
|
||||||
|
const row = `
|
||||||
|
<tr>
|
||||||
|
<td>${cat.nom}</td>
|
||||||
|
|
||||||
|
<td class="text-end">
|
||||||
|
<a href="../html/modifier_categorie.html?id=${cat.id}"
|
||||||
|
class="btn btn-sm btn-outline-primary me-1">
|
||||||
|
Modifier
|
||||||
|
</a>
|
||||||
|
|
||||||
|
<button class="btn btn-sm btn-outline-danger"
|
||||||
|
onclick="supprimerCategorie(${index})">
|
||||||
|
Supprimer
|
||||||
|
</button>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
`;
|
||||||
|
tableBody.innerHTML += row;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
afficherCategories();
|
||||||
|
|
||||||
|
// Suppression
|
||||||
|
function supprimerCategorie(index) {
|
||||||
|
if (confirm("Voulez-vous vraiment supprimer cette catégorie ?")) {
|
||||||
|
|
||||||
|
const nomCat = categories[index].nom;
|
||||||
|
|
||||||
|
categories.splice(index, 1);
|
||||||
|
|
||||||
|
afficherCategories();
|
||||||
|
|
||||||
|
successMsg.textContent = `La catégorie "${nomCat}" a été supprimée avec succès.`;
|
||||||
|
successMsg.classList.remove("d-none");
|
||||||
|
}
|
||||||
|
}
|
||||||
60
blog/js/modifier_article.js
Normal file
60
blog/js/modifier_article.js
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
const form = document.getElementById("editArticleForm");
|
||||||
|
const imgField = document.getElementById("articleImage");
|
||||||
|
const titleField = document.getElementById("articleTitle");
|
||||||
|
const contentField = document.getElementById("articleContent");
|
||||||
|
const categoryField = document.getElementById("articleCategory");
|
||||||
|
const publishedField = document.getElementById("articlePublished");
|
||||||
|
|
||||||
|
const errorEmpty = document.getElementById("errorEmpty");
|
||||||
|
const errorImage = document.getElementById("errorImage");
|
||||||
|
const errorExists = document.getElementById("errorExists");
|
||||||
|
const successMsg = document.getElementById("successMsg");
|
||||||
|
|
||||||
|
// Simulation BDD pour vérifier doublons
|
||||||
|
const titresExistants = [
|
||||||
|
"article de test",
|
||||||
|
"nouveautés chiens",
|
||||||
|
"actualité du mois",
|
||||||
|
];
|
||||||
|
|
||||||
|
form.addEventListener("submit", function (e) {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
const titre = titleField.value.trim().toLowerCase();
|
||||||
|
const fichierImage = imgField.files[0];
|
||||||
|
|
||||||
|
// Reset messages
|
||||||
|
errorEmpty.classList.add("d-none");
|
||||||
|
errorImage.classList.add("d-none");
|
||||||
|
errorExists.classList.add("d-none");
|
||||||
|
successMsg.classList.add("d-none");
|
||||||
|
|
||||||
|
//Titre obligatoire
|
||||||
|
if (titre === "") {
|
||||||
|
errorEmpty.classList.remove("d-none");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Titre déjà existant ?
|
||||||
|
if (titresExistants.includes(titre)) {
|
||||||
|
errorExists.classList.remove("d-none");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Vérification image
|
||||||
|
if (fichierImage) {
|
||||||
|
const validFormats = ["image/jpeg", "image/png", "image/gif"];
|
||||||
|
if (!validFormats.includes(fichierImage.type)) {
|
||||||
|
errorImage.classList.remove("d-none");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Succès
|
||||||
|
successMsg.classList.remove("d-none");
|
||||||
|
|
||||||
|
// Redirection après succès
|
||||||
|
setTimeout(() => {
|
||||||
|
window.location.href = "../../blog/html/accueil_blog.html";
|
||||||
|
}, 1500);
|
||||||
|
});
|
||||||
37
blog/js/modifier_categorie.js
Normal file
37
blog/js/modifier_categorie.js
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
const form = document.getElementById("modifierCategorie");
|
||||||
|
const nameField = document.getElementById("categoryName");
|
||||||
|
const descField = document.getElementById("categorieDescription");
|
||||||
|
|
||||||
|
// 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) {
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
// Vérification des champs obligatoires
|
||||||
|
if (nameField.value.trim() === "" || descField.value.trim() === "") {
|
||||||
|
showMessage("danger", "Veuillez remplir tous les champs obligatoires");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Message succès
|
||||||
|
showMessage("success", "La catégorie a été modifiée avec succès !");
|
||||||
|
|
||||||
|
// Redirection après succès
|
||||||
|
setTimeout(() => {
|
||||||
|
window.location.href = "../html/accueil_blog.html";
|
||||||
|
}, 1500);
|
||||||
|
});
|
||||||
56
connexion/html/mot_de_passe_oublie.html
Normal file
56
connexion/html/mot_de_passe_oublie.html
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8" />
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
|
<title>Mot de passe oublié</title>
|
||||||
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" />
|
||||||
|
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background: #f4f6f981;
|
||||||
|
height: 100vh;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.forgot-password-card {
|
||||||
|
width: 100%;
|
||||||
|
max-width: 380px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<div class="card shadow forgot-password-card">
|
||||||
|
<div class="card-body p-4">
|
||||||
|
<h1 class="text-center mb-4 fs-3">Mot de passe oublié</h1>
|
||||||
|
<p class="text text-muted mb-4">
|
||||||
|
Nous avons besoin de votre adresse mail pour pouvoir réinitialiser
|
||||||
|
votre mot de passe.
|
||||||
|
</p>
|
||||||
|
<form>
|
||||||
|
<div class="mb-3">
|
||||||
|
<label class="form-label" for="email">Adresse e-mail</label>
|
||||||
|
|
||||||
|
<input type="email" class="form-control" placeholder="exemple@mail.com" required />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<button class="btn btn-primary w-100" type="submit">
|
||||||
|
Réinitialiser le mot de passe
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<div class="text-center mt-3">
|
||||||
|
<a href="../html/page_de_connexion.html" class="text-decoration-none">Retour à la connexion</a>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
||||||
@@ -26,32 +26,45 @@
|
|||||||
<body>
|
<body>
|
||||||
<div class="card shadow login-card">
|
<div class="card shadow login-card">
|
||||||
<div class="card-body p-4">
|
<div class="card-body p-4">
|
||||||
<h3 class="text-center mb-4">Connexion Admin</h3>
|
<h1 class="text-center mb-4 fs-3">Connexion Admin</h1>
|
||||||
|
|
||||||
<form>
|
<form>
|
||||||
<div class="mb-3">
|
<div class="mb-3">
|
||||||
<label class="form-label">Mot de passe</label>
|
|
||||||
|
<label class="form-label">Adresse e-mail </label>
|
||||||
|
<input
|
||||||
|
type="email"
|
||||||
|
class="form-control"
|
||||||
|
id="textInput"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
|
||||||
|
<label class="form-label" for="password">Mot de passe</label>
|
||||||
<input
|
<input
|
||||||
type="password"
|
type="password"
|
||||||
class="form-control"
|
class="form-control"
|
||||||
id="password"
|
id="password"
|
||||||
placeholder="••••••••"
|
|
||||||
/>
|
/>
|
||||||
<label for="showPassword">
|
<label for="showPassword" class="mt-2">
|
||||||
<input type="checkbox" id="showPassword" />
|
<input type="checkbox" id="showPassword" />
|
||||||
Voir le mot de passe
|
Voir le mot de passe
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<button class="btn btn-primary w-100">Se connecter</button>
|
<button class="btn btn-primary w-100" type="submit">Se connecter</button>
|
||||||
|
|
||||||
<div class="text-center mt-3">
|
<div class="text-center mt-3">
|
||||||
<a href="../mot_de_passe_oublie/mot_de_passe_oublie.html" class="text-decoration-none">Mot de passe oublié ?</a>
|
<a href="../html/mot_de_passe_oublie.html" class="text-decoration-none">Mot de passe oublié ?</a>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="page_de_connexion.js"></script>
|
<script src="../js/page_de_connexion.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>
|
||||||
|
|
||||||
@@ -26,8 +26,8 @@
|
|||||||
<body>
|
<body>
|
||||||
<div class="card shadow reset-password-card">
|
<div class="card shadow reset-password-card">
|
||||||
<div class="card-body p-4">
|
<div class="card-body p-4">
|
||||||
<h3 class="text-center mb-4">Nouveau mot de passe</h3>
|
<h1 class="text-center mb-4 fs-3">Nouveau mot de passe</h1>
|
||||||
<p class="text-center text-muted mb-4">
|
<p class="text text-muted mb-4">
|
||||||
Pour réinitialiser votre mot de passe, veuillez saisir un nouveau mot
|
Pour réinitialiser votre mot de passe, veuillez saisir un nouveau mot
|
||||||
de passe ainsi qu'une confirmation.
|
de passe ainsi qu'une confirmation.
|
||||||
|
|
||||||
@@ -35,14 +35,14 @@
|
|||||||
|
|
||||||
<div
|
<div
|
||||||
id="errorMsg"
|
id="errorMsg"
|
||||||
class="alert alert-danger text-center"
|
class="alert alert-danger text-center fs-1"
|
||||||
style="display: none"
|
style="display: none"
|
||||||
>
|
>
|
||||||
Les mots de passe ne correspondent pas.
|
Les mots de passe ne correspondent pas.
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<form id="resetForm">
|
<form id="resetForm">
|
||||||
<div class="mb-3">
|
<div class="mb-4">
|
||||||
<label class="form-label"
|
<label class="form-label"
|
||||||
>Nouveau mot de passe (minimum 8 caractères)</label
|
>Nouveau mot de passe (minimum 8 caractères)</label
|
||||||
>
|
>
|
||||||
@@ -52,12 +52,12 @@
|
|||||||
id="password"
|
id="password"
|
||||||
required
|
required
|
||||||
/>
|
/>
|
||||||
<small id="passwordIndicator" class="fw-bold"</small>
|
<small id="passwordIndicator" class="fw-bold"></small>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="mb-3">
|
<div class="mb-3">
|
||||||
<label class="form-label"
|
<label class="form-label"
|
||||||
>Confirmer le mot de passe (minimum 8 caractères)</label
|
>Confirmer le mot de passe</label
|
||||||
>
|
>
|
||||||
<input
|
<input
|
||||||
type="password"
|
type="password"
|
||||||
@@ -65,7 +65,7 @@
|
|||||||
id="confirmPassword"
|
id="confirmPassword"
|
||||||
required
|
required
|
||||||
/>
|
/>
|
||||||
<label for="showPassword">
|
<label for="showPassword" class="mt-3">
|
||||||
<input type="checkbox" id="showPassword" />
|
<input type="checkbox" id="showPassword" />
|
||||||
Voir le mot de passe
|
Voir le mot de passe
|
||||||
</label>
|
</label>
|
||||||
@@ -86,10 +86,15 @@
|
|||||||
<button class="btn btn-primary w-100" type="submit">
|
<button class="btn btn-primary w-100" type="submit">
|
||||||
Changer le mot de passe
|
Changer le mot de passe
|
||||||
</button>
|
</button>
|
||||||
|
<div class="text-center mt-3">
|
||||||
|
<a
|
||||||
|
href="../html/page_de_connexion.html"
|
||||||
|
class="text-decoration-none"
|
||||||
|
>Retour à la connexion</a
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script src="reinitialisation_du_mot_de_passe.js"></script>
|
<script src="../js/reinitialisation_du_mot_de_passe.js"></script>
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
@@ -49,6 +49,12 @@ form.addEventListener('submit', function(e) {
|
|||||||
errorMsg.textContent = 'Les mots de passe ne correspondent pas.';
|
errorMsg.textContent = 'Les mots de passe ne correspondent pas.';
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
successMsg.style.display = 'block';
|
||||||
|
|
||||||
|
// Redirection après 1 seconde
|
||||||
|
setTimeout(() => {
|
||||||
|
window.location.href = "../html/page_de_connexion.html";
|
||||||
|
}, 1000);
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
@@ -1,55 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<title>Mot de passe oublié</title>
|
|
||||||
<link
|
|
||||||
rel="stylesheet"
|
|
||||||
href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<style>
|
|
||||||
body {
|
|
||||||
background: #f4f6f981;
|
|
||||||
height: 100vh;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
.forgot-password-card {
|
|
||||||
width: 100%;
|
|
||||||
max-width: 380px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div class="card shadow forgot-password-card">
|
|
||||||
<div class="card-body p-4">
|
|
||||||
<h3 class="text-center mb-4">Mot de passe oublié</h3>
|
|
||||||
|
|
||||||
<form>
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label">Adresse e-mail</label>
|
|
||||||
<input
|
|
||||||
type="email"
|
|
||||||
class="form-control"
|
|
||||||
placeholder="exemple@mail.com"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<button class="btn btn-primary w-100">
|
|
||||||
Réinitialiser le mot de passe
|
|
||||||
</button>
|
|
||||||
|
|
||||||
<div class="text-center mt-3">
|
|
||||||
<a href="../page_de_connexion/page_de_connexion.html" class="text-decoration-none"
|
|
||||||
>Retour à la connexion</a
|
|
||||||
>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
10
css/avant_apres.css
Normal file
10
css/avant_apres.css
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
/*=============================================================================
|
||||||
|
Image Preview Styles
|
||||||
|
=============================================================================*/
|
||||||
|
|
||||||
|
.img-preview {
|
||||||
|
max-width: 150px;
|
||||||
|
border-radius: 8px;
|
||||||
|
display: none;
|
||||||
|
/* cachée tant qu'il n'y a pas d'image */
|
||||||
|
}
|
||||||
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;
|
||||||
|
}
|
||||||
41
css/style.css
Normal file
41
css/style.css
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
/*=============================================================================
|
||||||
|
Header Navbar Styles
|
||||||
|
=============================================================================*/
|
||||||
|
|
||||||
|
.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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
BIN
favicon.png
Normal file
BIN
favicon.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 980 B |
121
header.html
Normal file
121
header.html
Normal file
@@ -0,0 +1,121 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>CE sera le titre de la page</title>
|
||||||
|
<link href="node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
<link rel="stylesheet" href="node_modules/bs-icon/icons.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>
|
||||||
|
|
||||||
|
<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 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>
|
||||||
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
|
<header>
|
||||||
|
<h1 class="title fs-2">Titre de la page</h1>
|
||||||
|
</header>
|
||||||
|
<main>
|
||||||
|
Contenu de la page
|
||||||
|
</main>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
<script src="node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</html>
|
||||||
92
package-lock.json
generated
Normal file
92
package-lock.json
generated
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
{
|
||||||
|
"name": "backoffice_il_eau_chien",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"lockfileVersion": 3,
|
||||||
|
"requires": true,
|
||||||
|
"packages": {
|
||||||
|
"": {
|
||||||
|
"name": "backoffice_il_eau_chien",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"license": "OSEF",
|
||||||
|
"dependencies": {
|
||||||
|
"bootstrap": "^5.3.8",
|
||||||
|
"bs-icon": "^0.0.8",
|
||||||
|
"tinymce": "^8.2.2",
|
||||||
|
"tinymce-i18n": "^25.11.17"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@popperjs/core": {
|
||||||
|
"version": "2.11.8",
|
||||||
|
"resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz",
|
||||||
|
"integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==",
|
||||||
|
"peer": true,
|
||||||
|
"funding": {
|
||||||
|
"type": "opencollective",
|
||||||
|
"url": "https://opencollective.com/popperjs"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/bootstrap": {
|
||||||
|
"version": "5.3.8",
|
||||||
|
"resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-5.3.8.tgz",
|
||||||
|
"integrity": "sha512-HP1SZDqaLDPwsNiqRqi5NcP0SSXciX2s9E+RyqJIIqGo+vJeN5AJVM98CXmW/Wux0nQ5L7jeWUdplCEf0Ee+tg==",
|
||||||
|
"funding": [
|
||||||
|
{
|
||||||
|
"type": "github",
|
||||||
|
"url": "https://github.com/sponsors/twbs"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "opencollective",
|
||||||
|
"url": "https://opencollective.com/bootstrap"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"peerDependencies": {
|
||||||
|
"@popperjs/core": "^2.11.8"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/bs-icon": {
|
||||||
|
"version": "0.0.8",
|
||||||
|
"resolved": "https://registry.npmjs.org/bs-icon/-/bs-icon-0.0.8.tgz",
|
||||||
|
"integrity": "sha512-tL+KDhh5VF/sEDUZquFXxrKrYnj91pGp4XHxSPbmVnTYIigsF9KyA+ts8x4RnjFT+s7HeZqpTB3k6CgmJcwfLw==",
|
||||||
|
"peerDependencies": {
|
||||||
|
"react": ">=16.13.1",
|
||||||
|
"react-dom": ">=16.13.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/react": {
|
||||||
|
"version": "19.2.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/react/-/react-19.2.1.tgz",
|
||||||
|
"integrity": "sha512-DGrYcCWK7tvYMnWh79yrPHt+vdx9tY+1gPZa7nJQtO/p8bLTDaHp4dzwEhQB7pZ4Xe3ok4XKuEPrVuc+wlpkmw==",
|
||||||
|
"peer": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">=0.10.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/react-dom": {
|
||||||
|
"version": "19.2.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.2.1.tgz",
|
||||||
|
"integrity": "sha512-ibrK8llX2a4eOskq1mXKu/TGZj9qzomO+sNfO98M6d9zIPOEhlBkMkBUBLd1vgS0gQsLDBzA+8jJBVXDnfHmJg==",
|
||||||
|
"peer": true,
|
||||||
|
"dependencies": {
|
||||||
|
"scheduler": "^0.27.0"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"react": "^19.2.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/scheduler": {
|
||||||
|
"version": "0.27.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.27.0.tgz",
|
||||||
|
"integrity": "sha512-eNv+WrVbKu1f3vbYJT/xtiF5syA5HPIMtf9IgY/nKg0sWqzAUEvqY/xm7OcZc/qafLx/iO9FgOmeSAp4v5ti/Q=="
|
||||||
|
},
|
||||||
|
"node_modules/tinymce": {
|
||||||
|
"version": "8.2.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/tinymce/-/tinymce-8.2.2.tgz",
|
||||||
|
"integrity": "sha512-CFDSZwciMvFGW2czK/Xig1HcOGpXI0qcQMIqaIcG2F4RuuTdf+LQTreyEZunAJoFTQ9L0KAugOqL7OA5TJkoAA=="
|
||||||
|
},
|
||||||
|
"node_modules/tinymce-i18n": {
|
||||||
|
"version": "25.11.17",
|
||||||
|
"resolved": "https://registry.npmjs.org/tinymce-i18n/-/tinymce-i18n-25.11.17.tgz",
|
||||||
|
"integrity": "sha512-Fi5hGRDL9o42VsdahgNgHRHO/4ClAAqIew45QMu8sa5LQT2wTaVPf/tAXnVDHxR7c6NWZQmZp/E18LosxLq42A=="
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
21
package.json
Normal file
21
package.json
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"name": "backoffice_il_eau_chien",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "Le header du back office",
|
||||||
|
"main": "index.js",
|
||||||
|
"scripts": {
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "ssh://git@git.lalanguebleue.fr:2222/ileauchiens/maquette_backoffice.git"
|
||||||
|
},
|
||||||
|
"author": "",
|
||||||
|
"license": "OSEF",
|
||||||
|
"dependencies": {
|
||||||
|
"bootstrap": "^5.3.8",
|
||||||
|
"bs-icon": "^0.0.8",
|
||||||
|
"tinymce": "^8.2.2",
|
||||||
|
"tinymce-i18n": "^25.11.17"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,90 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Ajouter une paire avant/après</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 {
|
|
||||||
max-width: 800px;
|
|
||||||
margin-top: 100px;
|
|
||||||
}
|
|
||||||
.img-preview {
|
|
||||||
max-width: 150px;
|
|
||||||
border-radius: 8px;
|
|
||||||
display: none; /* cachée tant qu'il n'y a pas d'image */
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
|
|
||||||
<h2 class="mb-5 text-center">Ajouter une paire avant/après</h2>
|
|
||||||
|
|
||||||
<!-- Message succès -->
|
|
||||||
<div id="successMsg" class="alert alert-success d-none">
|
|
||||||
Nouvelle paire ajoutée avec succès !
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Message erreur -->
|
|
||||||
<div id="errorMsg" class="alert alert-danger d-none">
|
|
||||||
Merci de remplir tous les champs obligatoires.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<form id="addPairForm">
|
|
||||||
|
|
||||||
<!-- Titre / label -->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label">Titre de la paire *</label>
|
|
||||||
<input type="text" id="pairTitle" class="form-control" required>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Type -->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label class="form-label">Type *</label>
|
|
||||||
<select id="pairType" class="form-select" required>
|
|
||||||
<option value="">-- Choisir --</option>
|
|
||||||
<option value="Chien">Chien</option>
|
|
||||||
<option value="Chat">Chat</option>
|
|
||||||
<option value="Autre">Autre</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image AVANT -->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label">Image AVANT *</label>
|
|
||||||
<input type="file" id="beforeImage" class="form-control" accept="image/*">
|
|
||||||
|
|
||||||
<img id="beforePreview" class="img-preview border mt-2">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image APRÈS -->
|
|
||||||
<div class="mb-4">
|
|
||||||
<label class="form-label">Image APRÈS *</label>
|
|
||||||
<input type="file" id="afterImage" class="form-control" accept="image/*">
|
|
||||||
|
|
||||||
<img id="afterPreview" class="img-preview border mt-2">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Boutons -->
|
|
||||||
<div class="d-flex justify-content-between">
|
|
||||||
<a href="../liste_avant_apres/liste_avant_apres.html" class="btn btn-secondary">Annuler</a>
|
|
||||||
<button type="submit" class="btn btn-primary">Ajouter</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="ajouter_avant_apres.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,60 +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 paires avant/apres</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 paires avant/apres</h2>
|
|
||||||
|
|
||||||
<!--Message succès-->
|
|
||||||
<div id="succesDeleteMsg" class="alert alert-success d-none">Paire supprimée avec succès !</div>
|
|
||||||
|
|
||||||
<div class="d-flex justify-content-end mb-4">
|
|
||||||
<a href="../ajouter_avant_apres/ajouter_avant_apres.html" class="btn btn-primary">Ajouter une paire</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
<table class="table table-striped table-hover align-middle">
|
|
||||||
<thead class="table-dark">
|
|
||||||
<tr>
|
|
||||||
<th>Titre paire</th>
|
|
||||||
<th>Type</th>
|
|
||||||
<th>Avant</th>
|
|
||||||
<th>Apres</th>
|
|
||||||
<th class="text-center">Actions</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
|
|
||||||
<tbody id="prestationTableBody">
|
|
||||||
<!--JS-->
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="liste_avant_apres.js"></script>
|
|
||||||
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,90 +0,0 @@
|
|||||||
// ===============================
|
|
||||||
// Données simulées (à remplacer plus tard par une BDD)
|
|
||||||
// ===============================
|
|
||||||
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 tableBody = document.getElementById("prestationTableBody");
|
|
||||||
const succesDeleteMsg = document.getElementById("succesDeleteMsg");
|
|
||||||
|
|
||||||
// ===============================
|
|
||||||
// Fonction d'affichage
|
|
||||||
// ===============================
|
|
||||||
function displayPairs() {
|
|
||||||
tableBody.innerHTML = ""; // reset tableau
|
|
||||||
|
|
||||||
galleryPairs.forEach(pair => {
|
|
||||||
const row = document.createElement("tr");
|
|
||||||
|
|
||||||
row.innerHTML = `
|
|
||||||
<td>${pair.titre}</td>
|
|
||||||
<td>${pair.type}</td>
|
|
||||||
|
|
||||||
<td>
|
|
||||||
<img src="${pair.avant}" width="80" class="rounded">
|
|
||||||
</td>
|
|
||||||
|
|
||||||
<td>
|
|
||||||
<img src="${pair.apres}" width="80" class="rounded">
|
|
||||||
</td>
|
|
||||||
|
|
||||||
<td class="text-center action-btns">
|
|
||||||
|
|
||||||
<!-- Bouton Voir -->
|
|
||||||
<a href="../voir_avant_apres/voir_avant_apres.html?id=${pair.id}"
|
|
||||||
class="btn btn-info btn-sm">Voir</a>
|
|
||||||
|
|
||||||
<!-- Bouton Modifier -->
|
|
||||||
<a href="../modifier_avant_apres/modifier_avant_apres.html?id=${pair.id}"
|
|
||||||
class="btn btn-warning btn-sm">Modifier</a>
|
|
||||||
|
|
||||||
<!-- Bouton Supprimer -->
|
|
||||||
<button class="btn btn-danger btn-sm" onclick="deletePair(${pair.id})">
|
|
||||||
Supprimer
|
|
||||||
</button>
|
|
||||||
</td>
|
|
||||||
`;
|
|
||||||
|
|
||||||
tableBody.appendChild(row);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// ===============================
|
|
||||||
// Fonction de suppression
|
|
||||||
// ===============================
|
|
||||||
function deletePair(id) {
|
|
||||||
if (!confirm("Voulez-vous vraiment supprimer cette paire ?")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
galleryPairs = galleryPairs.filter(pair => pair.id !== id);
|
|
||||||
displayPairs();
|
|
||||||
|
|
||||||
succesDeleteMsg.classList.remove("d-none");
|
|
||||||
|
|
||||||
// Disparaît après 2 secondes
|
|
||||||
setTimeout(() => {
|
|
||||||
succesDeleteMsg.classList.add("d-none");
|
|
||||||
}, 2000);
|
|
||||||
}
|
|
||||||
|
|
||||||
// ===============================
|
|
||||||
// Chargement initial
|
|
||||||
// ===============================
|
|
||||||
displayPairs();
|
|
||||||
|
|
||||||
@@ -1,104 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Modifier une paire avant/après</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;
|
|
||||||
max-width: 800px;
|
|
||||||
}
|
|
||||||
.img-preview {
|
|
||||||
max-width: 150px;
|
|
||||||
border-radius: 8px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
<h2 class="mb-5 text-center">Modifier une paire avant/après</h2>
|
|
||||||
|
|
||||||
<!-- Messages -->
|
|
||||||
<div id="successMsg" class="alert alert-success d-none">
|
|
||||||
La paire avant/après a été modifiée avec succès.
|
|
||||||
</div>
|
|
||||||
<div id="errorMsg" class="alert alert-danger d-none">
|
|
||||||
Une erreur est survenue. Merci de vérifier le formulaire.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Formulaire de modification -->
|
|
||||||
<form id="editPairForm">
|
|
||||||
|
|
||||||
<!-- ID caché -->
|
|
||||||
<input type="hidden" id="pairId">
|
|
||||||
|
|
||||||
<!-- Titre / label -->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label for="pairTitle" class="form-label">Titre / label de la paire *</label>
|
|
||||||
<input type="text" class="form-control" id="pairTitle" required>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Type -->
|
|
||||||
<div class="mb-3">
|
|
||||||
<label for="pairType" class="form-label">Type</label>
|
|
||||||
<select id="pairType" class="form-select">
|
|
||||||
<option value="Chien">Chien</option>
|
|
||||||
<option value="Chat">Chat</option>
|
|
||||||
<option value="Autre">Autre</option>
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image AVANT -->
|
|
||||||
<div class="mb-4 row">
|
|
||||||
<div class="col-md-6">
|
|
||||||
<label class="form-label" for="beforeImage">Image AVANT</label>
|
|
||||||
<input type="file" class="form-control" id="beforeImage" accept="image/*">
|
|
||||||
<div class="form-text">
|
|
||||||
Laisser vide pour conserver l'image actuelle.
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col-md-6 text-center">
|
|
||||||
<p class="mb-1">Aperçu actuel AVANT</p>
|
|
||||||
<img id="beforePreview" src="" alt="Image avant" class="img-preview border">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Image APRES -->
|
|
||||||
<div class="mb-4 row">
|
|
||||||
<div class="col-md-6">
|
|
||||||
<label class="form-label" for="afterImage">Image APRÈS</label>
|
|
||||||
<input type="file" class="form-control" id="afterImage" accept="image/*">
|
|
||||||
<div class="form-text">
|
|
||||||
Laisser vide pour conserver l'image actuelle.
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col-md-6 text-center">
|
|
||||||
<p class="mb-1">Aperçu actuel APRÈS</p>
|
|
||||||
<img id="afterPreview" src="" alt="Image après" class="img-preview border">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Boutons -->
|
|
||||||
<div class="d-flex justify-content-between">
|
|
||||||
<a href="../liste_avant_apres/liste_avant_apres.html" class="btn btn-secondary">
|
|
||||||
Annuler
|
|
||||||
</a>
|
|
||||||
<button type="submit" class="btn btn-primary">
|
|
||||||
Enregistrer les modifications
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="modifier_avant_apres.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,70 +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 la paire avant/après</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 {
|
|
||||||
max-width: 800px;
|
|
||||||
margin-top: 100px;
|
|
||||||
}
|
|
||||||
.img-preview {
|
|
||||||
max-width: 250px;
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container">
|
|
||||||
|
|
||||||
<h2 class="mb-5 text-center">Détails de la paire avant/après</h2>
|
|
||||||
|
|
||||||
<!-- Message erreur -->
|
|
||||||
<div id="errorMsg" class="alert alert-danger d-none">
|
|
||||||
Impossible d'afficher cette paire.
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="detailsSection">
|
|
||||||
|
|
||||||
<!-- Titre -->
|
|
||||||
<h4 id="pairTitle" class="text-center mb-4"></h4>
|
|
||||||
|
|
||||||
<div class="d-flex justify-content-around align-items-center mb-4">
|
|
||||||
|
|
||||||
<div class="text-center">
|
|
||||||
<p class="fw-bold">AVANT</p>
|
|
||||||
<img id="beforePreview" class="img-preview border" src="">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="text-center">
|
|
||||||
<p class="fw-bold">APRÈS</p>
|
|
||||||
<img id="afterPreview" class="img-preview border" src="">
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- Bouton retour -->
|
|
||||||
<div class="text-center mt-4">
|
|
||||||
<a href="../liste_avant_apres/liste_avant_apres.html" class="btn btn-secondary">
|
|
||||||
Retour à la liste
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<script src="voir_avant_apres.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
170
prestations/html/ajouter_avant_apres.html
Normal file
170
prestations/html/ajouter_avant_apres.html
Normal file
@@ -0,0 +1,170 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Ajouter un 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">
|
||||||
|
|
||||||
|
</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 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>
|
||||||
|
|
||||||
|
|
||||||
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
|
<header>
|
||||||
|
<h1 class="title fs-2">Ajouter un résultat en images (Avant / Après)</h1>
|
||||||
|
<!-- Message succès -->
|
||||||
|
<div id="successMsg" class="alert alert-success d-none">
|
||||||
|
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>
|
||||||
|
</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="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
||||||
144
prestations/html/liste_avant_apres.html
Normal file
144
prestations/html/liste_avant_apres.html
Normal file
@@ -0,0 +1,144 @@
|
|||||||
|
<!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>
|
||||||
|
|
||||||
|
<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>
|
||||||
|
|
||||||
|
<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>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
||||||
135
prestations/html/liste_slider.html
Normal file
135
prestations/html/liste_slider.html
Normal file
@@ -0,0 +1,135 @@
|
|||||||
|
<!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>
|
||||||
170
prestations/html/modifier_avant_apres.html
Normal file
170
prestations/html/modifier_avant_apres.html
Normal file
@@ -0,0 +1,170 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Modifier un 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">
|
||||||
|
</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 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>
|
||||||
|
|
||||||
|
<main class="my-5 fs-6">
|
||||||
|
<div class="container">
|
||||||
|
<header>
|
||||||
|
<h1 class="title fs-2">Modifier un résultat en images (Avant / Après)</h1>
|
||||||
|
|
||||||
|
<!-- Messages -->
|
||||||
|
<div id="successMsg" class="alert alert-success d-none">
|
||||||
|
Le résultat a été modifié avec succès.
|
||||||
|
</div>
|
||||||
|
<div id="errorMsg" class="alert alert-danger d-none">
|
||||||
|
Une erreur est survenue. Merci de vérifier le formulaire.
|
||||||
|
</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">
|
||||||
|
|
||||||
|
<!-- Formulaire de modification -->
|
||||||
|
<form id="editPairForm" class="mt-3">
|
||||||
|
|
||||||
|
<!-- ID caché -->
|
||||||
|
<input type="hidden" id="pairId">
|
||||||
|
|
||||||
|
<!-- Titre-->
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="pairTitle" class="form-label fw-bold">Titre du résultat
|
||||||
|
(obligatoire)</label>
|
||||||
|
<input type="text" class="form-control" id="pairTitle" 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>
|
||||||
|
|
||||||
|
<!-- Images AVANT / APRÈS -->
|
||||||
|
<div class="row gy-4 mb-4">
|
||||||
|
<!-- Image AVANT -->
|
||||||
|
<div class="col-12">
|
||||||
|
<label class="form-label fw-bold" for="beforeImage">
|
||||||
|
Image AVANT (obligatoire, formats acceptés : jpg, png, webp)
|
||||||
|
</label>
|
||||||
|
<input type="file" class="form-control" id="beforeImage" accept="image/*" required>
|
||||||
|
<img id="beforePreview" class="img-preview mt-2 d-none" src="#" alt="Aperçu avant">
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Image APRÈS -->
|
||||||
|
<div class="col-12">
|
||||||
|
<label class="form-label fw-bold" for="afterImage">
|
||||||
|
Image APRÈS (obligatoire, formats acceptés : jpg, png, webp)
|
||||||
|
</label>
|
||||||
|
<input type="file" class="form-control" id="afterImage" accept="image/*" required>
|
||||||
|
<img id="afterPreview" class="img-preview mt-2 d-none" src="#" alt="Aperçu après">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Boutons -->
|
||||||
|
<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">
|
||||||
|
Enregistrer les modifications
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
<script src="../js/modifier_avant_apres.js"></script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
||||||
292
prestations/html/prestation_accueil.html
Normal file
292
prestations/html/prestation_accueil.html
Normal file
@@ -0,0 +1,292 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="fr">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>CE sera le titre de la page</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">
|
||||||
|
</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 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>
|
||||||
|
<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>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
|
||||||
|
</body>
|
||||||
|
|
||||||
|
<script src="../../node_modules/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||||
|
|
||||||
|
</html>
|
||||||
63
prestations/html/voir_avant_apres.html
Normal file
63
prestations/html/voir_avant_apres.html
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
<!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">
|
||||||
|
|
||||||
|
</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>
|
||||||
@@ -30,13 +30,48 @@ const afterPreview = document.getElementById("afterPreview");
|
|||||||
|
|
||||||
const successMsg = document.getElementById("successMsg");
|
const successMsg = document.getElementById("successMsg");
|
||||||
const errorMsg = document.getElementById("errorMsg");
|
const errorMsg = document.getElementById("errorMsg");
|
||||||
|
const errorFormat = document.getElementById("errorFormat");
|
||||||
|
|
||||||
|
// Formats autorisés
|
||||||
|
const allowedTypes = ["image/jpeg", "image/png", "image/webp"];
|
||||||
|
|
||||||
// ===============================
|
// ===============================
|
||||||
// Prévisualisation images
|
// Fonctions utilitaires
|
||||||
|
// ===============================
|
||||||
|
function hideMessages() {
|
||||||
|
successMsg.classList.add("d-none");
|
||||||
|
errorMsg.classList.add("d-none");
|
||||||
|
errorFormat.classList.add("d-none");
|
||||||
|
}
|
||||||
|
|
||||||
|
function isValidFormat(file) {
|
||||||
|
if (!file) return false;
|
||||||
|
return allowedTypes.includes(file.type);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ===============================
|
||||||
|
// Prévisualisation image AVANT
|
||||||
|
// + contrôle du format
|
||||||
// ===============================
|
// ===============================
|
||||||
beforeInput.addEventListener("change", function () {
|
beforeInput.addEventListener("change", function () {
|
||||||
|
hideMessages();
|
||||||
|
|
||||||
const file = this.files[0];
|
const file = this.files[0];
|
||||||
if (!file) return;
|
|
||||||
|
if (!file) {
|
||||||
|
beforePreview.style.display = "none";
|
||||||
|
beforePreview.src = "#";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Vérif format
|
||||||
|
if (!isValidFormat(file)) {
|
||||||
|
errorFormat.classList.remove("d-none");
|
||||||
|
this.value = ""; // reset le champ
|
||||||
|
beforePreview.style.display = "none";
|
||||||
|
beforePreview.src = "#";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
const reader = new FileReader();
|
const reader = new FileReader();
|
||||||
reader.onload = e => {
|
reader.onload = e => {
|
||||||
@@ -46,9 +81,29 @@ beforeInput.addEventListener("change", function () {
|
|||||||
reader.readAsDataURL(file);
|
reader.readAsDataURL(file);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// ===============================
|
||||||
|
// Prévisualisation image APRÈS
|
||||||
|
// + contrôle du format
|
||||||
|
// ===============================
|
||||||
afterInput.addEventListener("change", function () {
|
afterInput.addEventListener("change", function () {
|
||||||
|
hideMessages();
|
||||||
|
|
||||||
const file = this.files[0];
|
const file = this.files[0];
|
||||||
if (!file) return;
|
|
||||||
|
if (!file) {
|
||||||
|
afterPreview.style.display = "none";
|
||||||
|
afterPreview.src = "#";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Vérif format
|
||||||
|
if (!isValidFormat(file)) {
|
||||||
|
errorFormat.classList.remove("d-none");
|
||||||
|
this.value = ""; // reset le champ
|
||||||
|
afterPreview.style.display = "none";
|
||||||
|
afterPreview.src = "#";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
const reader = new FileReader();
|
const reader = new FileReader();
|
||||||
reader.onload = e => {
|
reader.onload = e => {
|
||||||
@@ -64,23 +119,35 @@ afterInput.addEventListener("change", function () {
|
|||||||
form.addEventListener("submit", function (e) {
|
form.addEventListener("submit", function (e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
// Reset messages
|
hideMessages();
|
||||||
errorMsg.classList.add("d-none");
|
|
||||||
successMsg.classList.add("d-none");
|
|
||||||
|
|
||||||
// Validation simple
|
// Champs obligatoires
|
||||||
if (!titleInput.value.trim() || !typeInput.value.trim() || !beforeInput.files[0] || !afterInput.files[0]) {
|
if (
|
||||||
|
!titleInput.value.trim() ||
|
||||||
|
!typeInput.value.trim() ||
|
||||||
|
!beforeInput.files[0] ||
|
||||||
|
!afterInput.files[0]
|
||||||
|
) {
|
||||||
errorMsg.classList.remove("d-none");
|
errorMsg.classList.remove("d-none");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const beforeFile = beforeInput.files[0];
|
||||||
|
const afterFile = afterInput.files[0];
|
||||||
|
|
||||||
|
// Vérification format des deux images
|
||||||
|
if (!isValidFormat(beforeFile) || !isValidFormat(afterFile)) {
|
||||||
|
errorFormat.classList.remove("d-none");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Nouvelle entrée (simulation)
|
// Nouvelle entrée (simulation)
|
||||||
const newPair = {
|
const newPair = {
|
||||||
id: galleryPairs.length + 1,
|
id: galleryPairs.length + 1,
|
||||||
titre: titleInput.value.trim(),
|
titre: titleInput.value.trim(),
|
||||||
type: typeInput.value.trim(),
|
type: typeInput.value.trim(),
|
||||||
avant: URL.createObjectURL(beforeInput.files[0]),
|
avant: URL.createObjectURL(beforeFile),
|
||||||
apres: URL.createObjectURL(afterInput.files[0])
|
apres: URL.createObjectURL(afterFile)
|
||||||
};
|
};
|
||||||
|
|
||||||
galleryPairs.push(newPair);
|
galleryPairs.push(newPair);
|
||||||
103
prestations/js/liste_avant_apres.js
Normal file
103
prestations/js/liste_avant_apres.js
Normal file
@@ -0,0 +1,103 @@
|
|||||||
|
// ===============================
|
||||||
|
// 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();
|
||||||
@@ -19,6 +19,11 @@ const galleryPairs = [
|
|||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
// ===============================
|
||||||
|
// Formats d'images autorisés
|
||||||
|
// ===============================
|
||||||
|
const allowedTypes = ["image/jpeg", "image/png", "image/webp"];
|
||||||
|
|
||||||
// Sélecteurs
|
// Sélecteurs
|
||||||
const editForm = document.getElementById("editPairForm");
|
const editForm = document.getElementById("editPairForm");
|
||||||
const pairIdInput = document.getElementById("pairId");
|
const pairIdInput = document.getElementById("pairId");
|
||||||
@@ -31,6 +36,7 @@ const afterPreview = document.getElementById("afterPreview");
|
|||||||
|
|
||||||
const successMsg = document.getElementById("successMsg");
|
const successMsg = document.getElementById("successMsg");
|
||||||
const errorMsg = document.getElementById("errorMsg");
|
const errorMsg = document.getElementById("errorMsg");
|
||||||
|
const errorFormat = document.getElementById("errorFormat");
|
||||||
|
|
||||||
// ===============================
|
// ===============================
|
||||||
// Récup ID dans l'URL
|
// Récup ID dans l'URL
|
||||||
@@ -71,23 +77,39 @@ function loadPairData() {
|
|||||||
afterPreview.src = pair.apres;
|
afterPreview.src = pair.apres;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prévisu des nouvelles images
|
// ===============================
|
||||||
beforeInput.addEventListener("change", function () {
|
// Gestion du changement d'image
|
||||||
const file = this.files[0];
|
// ===============================
|
||||||
|
function handleImageChange(inputEl, previewEl) {
|
||||||
|
const file = inputEl.files[0];
|
||||||
if (!file) return;
|
if (!file) return;
|
||||||
|
|
||||||
|
// Vérification format
|
||||||
|
if (!allowedTypes.includes(file.type)) {
|
||||||
|
// Format non autorisé
|
||||||
|
errorFormat.classList.remove("d-none");
|
||||||
|
inputEl.value = ""; // reset du champ
|
||||||
|
previewEl.src = ""; // reset de la prévisu
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Format OK → on cache le message d'erreur
|
||||||
|
errorFormat.classList.add("d-none");
|
||||||
|
|
||||||
const reader = new FileReader();
|
const reader = new FileReader();
|
||||||
reader.onload = e => beforePreview.src = e.target.result;
|
reader.onload = e => {
|
||||||
|
previewEl.src = e.target.result;
|
||||||
|
};
|
||||||
reader.readAsDataURL(file);
|
reader.readAsDataURL(file);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prévisu des nouvelles images + contrôle format
|
||||||
|
beforeInput.addEventListener("change", function () {
|
||||||
|
handleImageChange(beforeInput, beforePreview);
|
||||||
});
|
});
|
||||||
|
|
||||||
afterInput.addEventListener("change", function () {
|
afterInput.addEventListener("change", function () {
|
||||||
const file = this.files[0];
|
handleImageChange(afterInput, afterPreview);
|
||||||
if (!file) return;
|
|
||||||
|
|
||||||
const reader = new FileReader();
|
|
||||||
reader.onload = e => afterPreview.src = e.target.result;
|
|
||||||
reader.readAsDataURL(file);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Soumission
|
// Soumission
|
||||||
@@ -96,6 +118,7 @@ editForm.addEventListener("submit", function (e) {
|
|||||||
|
|
||||||
errorMsg.classList.add("d-none");
|
errorMsg.classList.add("d-none");
|
||||||
successMsg.classList.add("d-none");
|
successMsg.classList.add("d-none");
|
||||||
|
errorFormat.classList.add("d-none");
|
||||||
|
|
||||||
if (!titleInput.value.trim()) {
|
if (!titleInput.value.trim()) {
|
||||||
errorMsg.textContent = "Le titre est obligatoire.";
|
errorMsg.textContent = "Le titre est obligatoire.";
|
||||||
@@ -103,7 +126,16 @@ editForm.addEventListener("submit", function (e) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ici ce serait un fetch vers l'API en vrai.
|
// Double check format côté submit (au cas où)
|
||||||
|
const filesToCheck = [beforeInput.files[0], afterInput.files[0]];
|
||||||
|
for (const file of filesToCheck) {
|
||||||
|
if (!file || !allowedTypes.includes(file.type)) {
|
||||||
|
errorFormat.classList.remove("d-none");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
successMsg.classList.remove("d-none");
|
successMsg.classList.remove("d-none");
|
||||||
|
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="fr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<title>Admin - Prestations</title>
|
|
||||||
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
||||||
|
|
||||||
<style>
|
|
||||||
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>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<div class="container text-center">
|
|
||||||
<h2 class="mb-5">Gestion des prestations</h2>
|
|
||||||
|
|
||||||
<div class="row g-4">
|
|
||||||
|
|
||||||
<!-- Prestations -->
|
|
||||||
<div class="col-md-4">
|
|
||||||
<a href="../liste_prestation/liste_prestation.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 les prestations</h4>
|
|
||||||
<p class="text-muted">Ajouter, modifier, supprimer les prestations.</p>
|
|
||||||
</div>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- 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>
|
|
||||||
</html>
|
|
||||||
@@ -1,65 +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="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
||||||
|
|
||||||
<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>
|
|
||||||
|
|
||||||
<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-end mb-4">
|
|
||||||
<a href="../../slider/ajouter_slider/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="liste_slider.js"></script>
|
|
||||||
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
Reference in New Issue
Block a user