145 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="fr">
 | |
| <head>
 | |
|     <meta charset="UTF-8">
 | |
|     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | |
|     <title>RépliQ - Générateur de bannière e-mail</title>
 | |
|     <style>
 | |
|         body {
 | |
|             font-family: Arial, sans-serif;
 | |
|             margin: 20px;
 | |
|             text-align: center;
 | |
|         }
 | |
|         .banner {
 | |
|             padding: 10px;
 | |
|             font-weight: bold;
 | |
|             margin-top: 20px;
 | |
|             border-radius: 5px;
 | |
|             display: inline-block;
 | |
|             width: auto;
 | |
|             min-width: 250px;
 | |
|             text-align: center;
 | |
|         }
 | |
|         .output-container {
 | |
|             margin-top: 20px;
 | |
|         }
 | |
|         .copy-btn {
 | |
|             margin-top: 10px;
 | |
|             padding: 8px 15px;
 | |
|             font-size: 14px;
 | |
|             cursor: pointer;
 | |
|             border: none;
 | |
|             background-color: #0078D7;
 | |
|             color: white;
 | |
|             border-radius: 5px;
 | |
|         }
 | |
|         .copy-btn:hover {
 | |
|             background-color: #005A9E;
 | |
|         }
 | |
|         #hiddenContainer {
 | |
|             position: absolute;
 | |
|             left: -9999px;
 | |
|             top: -9999px;
 | |
|         }
 | |
|     </style>
 | |
| </head>
 | |
| <body>
 | |
|     <h2>RépliQ - Générateur de bannière e-mail</h2>
 | |
|     <label for="action">Demander une :</label>
 | |
|     <select id="action">
 | |
|         <option value="Lecture">Lecture</option>
 | |
|         <option value="Action">Action</option>
 | |
|         <option value="Réponse">Réponse</option>
 | |
|     </select>
 | |
|     <br><br>
 | |
|     <label for="date">Date limite :</label>
 | |
|     <input type="date" id="date">
 | |
|     <br><br>
 | |
|     <button onclick="generateBanner()">Générer</button>
 | |
|     <button onclick="setASAP()">ASAP</button>
 | |
| 
 | |
|     <div class="output-container">
 | |
|         <div id="result" class="banner" style="display: none;"></div>
 | |
|         <button class="copy-btn" onclick="copyFormattedBanner()" style="display: none;" id="copyButton">Copier le bandeau</button>
 | |
|     </div>
 | |
| 
 | |
|     <div id="hiddenContainer"></div>
 | |
| 
 | |
|     <script>
 | |
|         function generateBanner() {
 | |
|             const action = document.getElementById("action").value;
 | |
|             const dateInput = document.getElementById("date").value;
 | |
|             const resultDiv = document.getElementById("result");
 | |
|             const copyButton = document.getElementById("copyButton");
 | |
|             const hiddenContainer = document.getElementById("hiddenContainer");
 | |
| 
 | |
|             if (!dateInput) {
 | |
|                 alert("Veuillez sélectionner une date ou utiliser le bouton ASAP.");
 | |
|                 return;
 | |
|             }
 | |
| 
 | |
|             const selectedDate = new Date(dateInput);
 | |
|             const formattedDate = selectedDate.toLocaleDateString("fr-FR");
 | |
|             const today = new Date();
 | |
|             const diffTime = selectedDate - today;
 | |
|             const diffDays = Math.ceil(diffTime / (1000 * 60 * 60 * 24));
 | |
| 
 | |
|             let bgColor = "#A8E6A3";
 | |
|             let textColor = "#206A1E";
 | |
|             let message = `${action} souhaitée avant le ${formattedDate}.`;
 | |
| 
 | |
|             if (diffDays <= 3) {
 | |
|                 bgColor = "#FFD580";
 | |
|                 textColor = "#A65E00";
 | |
|             }
 | |
| 
 | |
|             if (action === "Lecture") {
 | |
|                 message += "<br>Inutile de répondre.";
 | |
|             }
 | |
| 
 | |
|             resultDiv.style.backgroundColor = bgColor;
 | |
|             resultDiv.style.color = textColor;
 | |
|             resultDiv.innerHTML = message;
 | |
|             resultDiv.style.display = "block";
 | |
|             copyButton.style.display = "inline-block";
 | |
| 
 | |
|             // Mettre le HTML formaté dans un conteneur caché
 | |
|             hiddenContainer.innerHTML = `<div style='background-color: ${bgColor}; color: ${textColor}; padding: 10px; font-weight: bold; border-radius: 5px; display: inline-block; text-align: left;'>${message}</div>`;
 | |
|         }
 | |
| 
 | |
|         function setASAP() {
 | |
|             const action = document.getElementById("action").value;
 | |
|             const resultDiv = document.getElementById("result");
 | |
|             const copyButton = document.getElementById("copyButton");
 | |
|             const hiddenContainer = document.getElementById("hiddenContainer");
 | |
| 
 | |
|             resultDiv.style.backgroundColor = "#FFA8A8";
 | |
|             resultDiv.style.color = "#8B0000";
 | |
|             let message = `${action} souhaitée dès que possible.`;
 | |
| 
 | |
|             if (action === "Lecture") {
 | |
|                 message += "<br>Inutile de répondre.";
 | |
|             }
 | |
| 
 | |
|             resultDiv.innerHTML = message;
 | |
|             resultDiv.style.display = "block";
 | |
|             copyButton.style.display = "inline-block";
 | |
| 
 | |
|             // Mettre le HTML formaté dans un conteneur caché
 | |
|             hiddenContainer.innerHTML = `<div style='background-color: #FFA8A8; color: #8B0000; padding: 10px; font-weight: bold; border-radius: 5px; display: inline-block; text-align: left;'>${message}</div>`;
 | |
|         }
 | |
| 
 | |
|         function copyFormattedBanner() {
 | |
|             const hiddenContainer = document.getElementById("hiddenContainer");
 | |
|             const range = document.createRange();
 | |
|             range.selectNode(hiddenContainer);
 | |
|             window.getSelection().removeAllRanges();
 | |
|             window.getSelection().addRange(range);
 | |
|             document.execCommand("copy");
 | |
|             window.getSelection().removeAllRanges();
 | |
|             alert("Bandeau copié ! Collez-le directement dans Outlook.");
 | |
|         }
 | |
|     </script>
 | |
| </body>
 | |
| </html>
 |