drupal-quartiersdedemain/web/modules/custom/q2d_mod/assets/js/carte-interactive-qdd.js

188 lines
7.8 KiB
JavaScript
Raw Normal View History

2024-11-05 21:45:42 +01:00
// Sélection des éléments principaux
2024-10-01 21:57:47 +02:00
const svgElement = document.querySelector('#sites-map-container svg');
const popup = document.querySelector('#sites-map-container #popup');
const popupContent = document.querySelector('#sites-map-container #popup-content');
const modalBackground = document.querySelector('#sites-map-container #modal-background');
2024-11-07 23:26:33 +01:00
// Vérification de la page courante
2024-11-08 01:12:49 +01:00
const isHomePage = document.querySelector('main#home') !== null;
const isLessitesPage = document.querySelector('div#lessites') !== null;
2024-11-07 23:26:33 +01:00
const isNodeTypeSitePage = document.body.classList.contains('node-type-site');
2024-11-08 01:12:49 +01:00
// Identifier le cercle de la page courante pour node-type-site
let currentPageCircle = null;
2024-11-08 12:00:04 +01:00
let lastHoveredCircle = null; // Variable pour conserver le dernier cercle survolé
2024-11-08 01:12:49 +01:00
if (isNodeTypeSitePage) {
const body = document.querySelector('body');
const pageIdMatch = body.className.match(/node-id-(\d+)/);
if (pageIdMatch) {
const pageId = pageIdMatch[1];
currentPageCircle = document.querySelector(`#site-${pageId} circle`);
if (currentPageCircle) {
currentPageCircle.setAttribute('fill', 'red'); // Met en rouge le cercle correspondant
}
}
}
2024-10-01 21:57:47 +02:00
// Fonction pour afficher le popup
2024-11-07 23:26:33 +01:00
function showPopup(content) {
2024-10-01 21:57:47 +02:00
popupContent.innerHTML = content;
popup.style.display = 'block';
2024-10-04 14:21:09 +02:00
modalBackground.style.display = 'block';
2024-10-01 21:57:47 +02:00
}
// Fonction pour fermer le popup
function closePopup() {
popup.style.display = 'none';
2024-11-07 09:20:04 +01:00
modalBackground.style.display = 'none';
2024-10-01 21:57:47 +02:00
}
2024-11-07 23:26:33 +01:00
// Gérer le survol des cercles en fonction de la page
2024-10-07 14:55:03 +02:00
svgElement.addEventListener('mouseover', function(event) {
2024-10-01 21:57:47 +02:00
if (event.target.classList.contains('site-link')) {
const content = event.target.getAttribute('data-content');
2024-11-07 09:20:04 +01:00
const dataId = event.target.getAttribute('data-id');
2024-11-05 21:45:42 +01:00
const correspondingRow = document.querySelector(`.views-row[data-id="${dataId}"]`);
2024-11-07 23:26:33 +01:00
// Interaction pour la page d'accueil
if (isHomePage) {
showPopup(content); // Affiche le popup
2024-11-08 12:00:04 +01:00
if (lastHoveredCircle && lastHoveredCircle !== event.target) {
lastHoveredCircle.setAttribute('fill', 'black'); // Remettre le dernier cercle survolé en noir
}
event.target.setAttribute('fill', 'red'); // Met le cercle en rouge
lastHoveredCircle = event.target; // Mettre à jour le cercle survolé
2024-11-07 23:26:33 +01:00
}
// Interaction pour la page #lessites
if (isLessitesPage && correspondingRow) {
correspondingRow.style.border = '2px solid red'; // Bordure rouge autour du .views-row correspondant
}
2024-10-01 21:57:47 +02:00
}
2024-11-07 23:26:33 +01:00
2024-11-08 01:12:49 +01:00
// Applique une couleur rouge au cercle au survol, sauf pour le cercle de la page courante
if (event.target.tagName === 'circle' && event.target !== currentPageCircle) {
2024-10-08 11:47:01 +02:00
event.target.setAttribute('fill', 'red');
}
2024-10-01 21:57:47 +02:00
});
2024-11-08 01:12:49 +01:00
// Gérer la sortie de survol des cercles en fonction de la page, avec exception pour le cercle de la page courante
2024-10-07 14:55:03 +02:00
svgElement.addEventListener('mouseout', function(event) {
2024-11-08 01:12:49 +01:00
// Ignorer le mouseout pour le cercle correspondant à la page courante dans node-type-site
if (event.target === currentPageCircle) {
return;
}
2024-10-07 14:55:03 +02:00
if (event.target.classList.contains('site-link')) {
2024-11-05 21:45:42 +01:00
const dataId = event.target.getAttribute('data-id');
const correspondingRow = document.querySelector(`.views-row[data-id="${dataId}"]`);
2024-11-07 23:26:33 +01:00
// Ferme le popup pour la page d'accueil
if (isHomePage) {
2024-11-08 12:00:04 +01:00
// closePopup();
return;
2024-11-07 23:26:33 +01:00
}
// Supprime la bordure rouge autour du .views-row pour la page #lessites
if (isLessitesPage && correspondingRow) {
correspondingRow.style.border = 'none';
}
2024-10-01 21:57:47 +02:00
}
2024-11-07 23:26:33 +01:00
2024-11-08 01:12:49 +01:00
// Remet la couleur noire au cercle lorsqu'on quitte le survol, sauf pour le cercle de la page courante
if (event.target.tagName === 'circle' && event.target !== currentPageCircle) {
2024-11-07 09:20:04 +01:00
event.target.setAttribute('fill', 'black');
2024-10-08 11:47:01 +02:00
}
2024-10-01 21:57:47 +02:00
});
2024-10-08 14:44:25 +02:00
2024-11-08 12:00:04 +01:00
2024-11-08 01:12:49 +01:00
// Gérer les clics pour la page node-type-site uniquement
2024-10-08 15:21:09 +02:00
svgElement.addEventListener('click', function(event) {
2024-11-07 23:26:33 +01:00
if (isNodeTypeSitePage) {
if (event.target.classList.contains('site-link')) {
const targetUrl = event.target.getAttribute('data-url');
if (targetUrl) {
window.location.href = targetUrl; // Redirige vers le data-url correspondant
}
2024-11-07 09:20:04 +01:00
}
2024-10-08 15:21:09 +02:00
}
});
2024-10-08 21:10:45 +02:00
2024-11-08 01:12:49 +01:00
// Fonction pour gérer l'agrandissement de views-row au survol des cercles
if (isLessitesPage) {
const circles = svgElement.querySelectorAll('circle.site-link');
circles.forEach(circle => {
// Récupérer l'URL du projet depuis le `data-url` du cercle
const projectUrl = new URL(circle.getAttribute('data-url'), window.location.origin).pathname;
circle.addEventListener('mouseover', function() {
// Sélectionner le .views-row correspondant
const correspondingRow = Array.from(document.querySelectorAll('.views-row')).find(row => {
const rowLink = row.querySelector('a[href]');
return rowLink && new URL(rowLink.getAttribute('href'), window.location.origin).pathname === projectUrl;
});
// Si un .views-row correspondant est trouvé, on augmente sa taille
if (correspondingRow) {
2024-11-08 11:10:24 +01:00
correspondingRow.style.transform = 'scale(1.05)';
2024-11-08 01:12:49 +01:00
correspondingRow.style.transition = 'transform 0.2s ease'; // Animation fluide
}
});
circle.addEventListener('mouseout', function() {
// Sélectionner le .views-row correspondant
const correspondingRow = Array.from(document.querySelectorAll('.views-row')).find(row => {
const rowLink = row.querySelector('a[href]');
return rowLink && new URL(rowLink.getAttribute('href'), window.location.origin).pathname === projectUrl;
});
// Remettre la taille d'origine du .views-row
if (correspondingRow) {
correspondingRow.style.transform = 'scale(1)'; // Taille d'origine
}
});
});
// Gérer le survol des .views-row pour surligner le cercle correspondant
const viewsRows = document.querySelectorAll('.views-row');
viewsRows.forEach(row => {
// Récupère l'URL du projet dans le premier lien <a>
const link = row.querySelector('a[href]');
if (!link) return; // Passe si aucun lien n'est trouvé
const projectUrl = new URL(link.getAttribute('href'), window.location.origin).pathname;
row.addEventListener('mouseover', function() {
// Sélectionne le cercle qui a la même URL dans data-url
const correspondingCircle = Array.from(svgElement.querySelectorAll('circle')).find(circle => {
const circleUrl = new URL(circle.getAttribute('data-url'), window.location.origin).pathname;
return circleUrl === projectUrl;
});
// Si un cercle correspondant est trouvé, le mettre en rouge
if (correspondingCircle) {
correspondingCircle.setAttribute('fill', 'red'); // Surligne le cercle correspondant
}
});
row.addEventListener('mouseout', function() {
// Sélectionne le cercle qui a la même URL dans data-url
const correspondingCircle = Array.from(svgElement.querySelectorAll('circle')).find(circle => {
const circleUrl = new URL(circle.getAttribute('data-url'), window.location.origin).pathname;
return circleUrl === projectUrl;
});
// Remettre le cercle à sa couleur initiale
if (correspondingCircle && correspondingCircle !== currentPageCircle) {
correspondingCircle.setAttribute('fill', 'black'); // Remet le cercle à sa couleur initiale
}
});
});
2024-11-07 23:26:33 +01:00
}
2024-11-08 12:00:04 +01:00