Compare commits

..

28 Commits

Author SHA1 Message Date
ouidade f60cb1b088 carte fixe 2024-10-15 16:29:51 +02:00
ouidade df628691bc fonts popup 2024-10-09 09:46:33 +02:00
ouidade bd2f2668f7 width header pour pb click carte 2024-10-08 22:00:01 +02:00
ouidade 55c74b64b3 ordiateur position popup 2024-10-08 21:50:00 +02:00
ouidade abc8fadc3f ipad position popup 2024-10-08 21:41:58 +02:00
ouidade 24d9656058 mobile position popup 2024-10-08 21:34:01 +02:00
ouidade caa62e7692 mobile position popup 2024-10-08 21:10:45 +02:00
ouidade 3fc1580186 map zone interactive plus grande 2024-10-08 15:28:39 +02:00
ouidade 318c34c629 map zone interactive plus grande 2024-10-08 15:27:19 +02:00
ouidade f762c02b8e map zone interactive plus grande 2024-10-08 15:23:38 +02:00
ouidade 4c3717df81 map zone interactive plus grande 2024-10-08 15:21:09 +02:00
ouidade 32221214bb map responsive fond popup @ media 2024-10-08 15:13:17 +02:00
ouidade 5f70faf3d4 map responsive fond popup @ media 2024-10-08 14:57:04 +02:00
ouidade 452d640680 map responsive fond popup 2024-10-08 14:50:59 +02:00
ouidade 0f3c160735 map responsive 2024-10-08 14:44:25 +02:00
ouidade 541aaff83c font-size popup 2024-10-08 14:05:17 +02:00
ouidade 237abad7e1 poisiton popup 2024-10-08 14:00:26 +02:00
ouidade 681fb0398e pointer events croix, facilité mouseover 2024-10-08 13:12:55 +02:00
ouidade b9f8612f16 map plus grande 2024-10-08 12:49:39 +02:00
ouidade d7986309bc js change color mouseover 2024-10-08 11:47:01 +02:00
ouidade 6229ea3e4f position popup 2024-10-07 15:50:16 +02:00
ouidade fb72032d08 position popup 2024-10-07 15:37:04 +02:00
ouidade 2835aecb23 position popup 2024-10-07 14:58:30 +02:00
ouidade 8440fc97c6 position popup 2024-10-07 14:55:03 +02:00
ouidade 272f371f43 block map 2024-10-04 15:10:06 +02:00
ouidade 9668e6368a display position popup 2024-10-04 15:02:19 +02:00
ouidade 806988276f display none voir site 2024-10-04 14:49:05 +02:00
ouidade 23d8823a45 taille path 2024-10-04 14:21:09 +02:00
15 changed files with 490 additions and 163 deletions

View File

@ -1,57 +0,0 @@
@font-face {
font-family: 'gilroy-semibold';
src: url('fonts/Gilroy/gilroy-semibold-webfont.woff') format('woff');
}
#sites-map-container {
background-color: #c3cef2;
text-align: center;
}
/* #sites-map-container .circle {
fill: black;
stroke: white;
stroke-width: 0.7;
} */
/* Changer la couleur au survol (hover) */
#sites-map-container .site-link:hover{
cursor: pointer;
}
#sites-map-container .site-link:hover circle.circle {
fill: #f7002b!important;
}
/* Styles du popup (caché par défaut) */
#sites-map-container #popup {
font-family: 'gilroy-semibold';
display: none;
position: fixed;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
z-index: 1000;
}
#sites-map-container strong{
color: #f7002b;
font-family: 'gilroy-semibold';
}
#sites-map-container a{
display: inline-flex;
align-items: center;
color: white;
background: black;
text-transform: uppercase;
font-size: 0.8rem;
padding-left: 0.5rem;
text-decoration: none;
margin-top: 0.7rem;
height: 1.3rem;
}
#sites-map-container a:after{
display: inline-flex;
content: url("../img/noun-arrow-to-right.svg");
padding-right: 0.2rem;
padding-left: 0.2rem;
}

View File

@ -0,0 +1,96 @@
@font-face {
font-family: 'gilroy-semibold';
src: url('../css/fonts/Gilroy/gilroy-semibold-webfont.woff') format('woff');
}
#sites-map-container {
background-color: #cecfcc;
text-align: center;
position: relative;
width: 100%; /* Prend toute la largeur du conteneur parent */
max-width: 800px; /* Optionnel : Limiter la largeur maximale */
margin: 0 auto; /* Centrer le conteneur */
height: auto; /* Permet à la hauteur de s'ajuster automatiquement */
@media (max-width: 810px) {
width: 80%; /* Prend toute la largeur du conteneur parent */
}
@media (max-width: 530px) {
width: 100%; /* Prend toute la largeur du conteneur parent */
height: 485px;
}
@media (max-width: 400px) {
width: 100%; /* Prend toute la largeur du conteneur parent */
height: 430px;
}
}
/* Changer la couleur au survol (hover) */
#sites-map-container .site-link:hover{
cursor: pointer;
}
/* Styles du popup (caché par défaut) */
#sites-map-container #popup {
font-family: 'gilroy-light';
display: none;
position: absolute;
z-index: 1000;
text-align: left;
padding-left: 1rem;
pointer-events: none;
@media (max-width: 1090px) {
bottom: 20px;
}
}
/* Position du popup à droite lorsque l'écran est plus grand que 1090px */
@media (min-width: 1090px) {
#sites-map-container #popup {
top: 50%; /* Centrer verticalement */
left: 80%; /* Placer le popup à droite de la carte */
transform: translateY(-50%); /* Ajuster pour centrer verticalement */
width: 300px;
}
}
#sites-map-container strong{
color: #f7002b;
font-family: 'gilroy-bold';
}
#sites-map-container a{
display: none;
align-items: center;
color: white;
background: black;
text-transform: uppercase;
font-size: 0.8rem;
padding-left: 0.5rem;
text-decoration: none;
margin-top: 0.7rem;
height: 1.3rem;
}
#sites-map-container a:after{
display: inline-flex;
content: url("../img/noun-arrow-to-right.svg");
padding-right: 0.2rem;
padding-left: 0.2rem;
}
#popup-content{
width: 300px;
p{
font-size: 0.7rem;
}
@media (max-width : 810px) {
width: 300px;
background-color: white;
border-radius: 5px;
padding: 0.5rem;
padding-left: 1rem;
}
}

View File

@ -1,59 +1,97 @@
// Sélection des éléments au préalable pour éviter de les rechercher plusieurs fois // // Sélection des éléments principaux
const svgElement = document.querySelector('#sites-map-container svg'); const svgElement = document.querySelector('#sites-map-container svg');
const popup = document.querySelector('#sites-map-container #popup'); const popup = document.querySelector('#sites-map-container #popup');
const popupContent = document.querySelector('#sites-map-container #popup-content'); const popupContent = document.querySelector('#sites-map-container #popup-content');
const modalBackground = document.querySelector('#sites-map-container #modal-background'); const modalBackground = document.querySelector('#sites-map-container #modal-background');
console.log('svgElement', svgElement);
// Fonction pour afficher le popup // Fonction pour afficher le popup
function showPopup(content, x, y) { function showPopup(content, x, y, isLeftHalf) {
console.log('showPopup', content, x, y);
popupContent.innerHTML = content; popupContent.innerHTML = content;
// Récupérer la position de l'élément SVG seulement une fois // // Récupérer la position et les dimensions du conteneur SVG
const rect = svgElement.getBoundingClientRect(); // const rect = svgElement.getBoundingClientRect();
// Calculer la position du popup par rapport à l'élément SVG // // Récupérer la position de défilement (scroll) de la page
const popupX = rect.left + x + 120; // Décalage de 120px à droite // const scrollX = window.scrollX;
const popupY = rect.top + y + 20; // Décalage de 20px en dessous // const scrollY = window.scrollY;
// Dimensions de la fenêtre et du popup // // Variables pour stocker les positions calculées du popup
const viewportWidth = window.innerWidth; // let popupX, popupY;
const viewportHeight = window.innerHeight;
const popupWidth = popup.offsetWidth;
const popupHeight = popup.offsetHeight;
// Vérification des bordures droite et gauche // // Afficher temporairement le popup pour mesurer ses dimensions
if (popupX + popupWidth > viewportWidth) { // popup.style.display = 'block';
popupX = viewportWidth - popupWidth - 10; // Ajuster pour qu'il ne dépasse pas à droite // const popupWidth = popup.offsetWidth;
} // const popupHeight = popup.offsetHeight;
if (popupX < 0) {
popupX = 10; // S'assurer que le popup ne dépasse pas à gauche
}
// Vérification des bordures inférieure et supérieure
if (popupY + popupHeight > viewportHeight) {
popupY = viewportHeight - popupHeight - 10; // Ajuster pour qu'il ne dépasse pas en bas
}
if (popupY < 0) {
popupY = 10; // S'assurer que le popup ne dépasse pas en haut
}
popup.style.left = `${popupX}px`;
popup.style.top = `${popupY}px`; // // // Vérifier si le point est dans la moitié gauche ou droite du SVG
// // if (isLeftHalf) {
// // console.log('Le point est dans la moitié gauche');
// // // Aligner le popup à gauche du cercle
// // popupX = rect.left + x -scrollX - popupWidth - 800; // Ajuster ici si nécessaire
// // popupContent.style.textAlign = 'right'; // Alignement du texte à droite
// // } else {
// // console.log('Le point est dans la moitié droite');
// // // Aligner le popup à droite du cercle
// popupX = rect.left + x + scrollX - popupWidth ;
// popupContent.style.textAlign = 'left'; // Alignement du texte à gauche
// // }
// // // Calculer la position Y avec un ajustement pour éviter qu'il soit trop bas
// const offsetY = - popupHeight - 10; // Ajuster la position vers le haut avec un décalage
// popupY = rect.top + offsetY; // Centrer verticalement, puis ajuster
// // console.log('rect.top:', rect.top);
// // console.log('y:', y);
// // console.log('scrollY:', scrollY);
// // console.log('popupHeight:', popupHeight);
// // console.log('offsetY:', offsetY);
// // // Empêcher le popup de dépasser les bords de l'écran
// // const viewportWidth = window.innerWidth;
// // const viewportHeight = window.innerHeight;
// // // Vérifier si le popup dépasse à droite de l'écran
// // if (popupX + popupWidth > viewportWidth) {
// // popupX = viewportWidth - popupWidth - 10; // Ajustement à droite
// // }
// // // Vérifier si le popup dépasse à gauche
// // if (popupX < 10) {
// // popupX = 10; // Ajustement à gauche
// // }
// // // Vérifier si le popup dépasse en bas
// // if (popupY + popupHeight > viewportHeight) {
// // popupY = viewportHeight - popupHeight - 10; // Ajustement en bas
// // }
// // // Vérifier si le popup dépasse en haut
// // if (popupY < 10) {
// // popupY = 10; // Ajustement en haut
// // }
// // Appliquer les positions calculées au popup
// popup.style.left = `${popupX}px`;
// popup.style.top = `${popupY}px`;
// Afficher le popup et le fond de modal
popup.style.display = 'block'; popup.style.display = 'block';
modalBackground.style.display = 'block'; // Activer le fond modal si nécessaire modalBackground.style.display = 'block';
// console.log(`Popup affiché à x: ${popupX}, y: ${popupY}`);
} }
// Recalculer la position du popup lors du redimensionnement de la fenêtre // // Recalculer la position du popup lors du redimensionnement de la fenêtre
window.addEventListener('resize', function() { // window.addEventListener('resize', function() {
if (popup.style.display === 'block') { // if (popup.style.display === 'block') {
// Recalculer les coordonnées et ajuster la position // const currentPopupRect = popup.getBoundingClientRect();
const currentPopupRect = popup.getBoundingClientRect(); // const rect = svgElement.getBoundingClientRect();
showPopup(popupContent.innerHTML, currentPopupRect.left, currentPopupRect.top); // showPopup(popupContent.innerHTML, currentPopupRect.left - rect.left, currentPopupRect.top - rect.top);
} // }
}); // });
// Fonction pour fermer le popup // Fonction pour fermer le popup
function closePopup() { function closePopup() {
@ -61,31 +99,85 @@ function closePopup() {
modalBackground.style.display = 'none'; // Désactiver le fond modal modalBackground.style.display = 'none'; // Désactiver le fond modal
} }
// Ajout d'un écouteur d'événement sur l'élément SVG pour tous les cercles // Gérer le survol des cercles (au lieu du clic)
svgElement.addEventListener('click', function(event) { svgElement.addEventListener('mouseover', function(event) {
console.log('svgElement click', event.target);
if (event.target.classList.contains('site-link')) { if (event.target.classList.contains('site-link')) {
// Récupérer le contenu personnalisé de l'attribut data-content
const content = event.target.getAttribute('data-content'); const content = event.target.getAttribute('data-content');
// Récupérer la position du cercle cliqué par rapport à l'élément SVG // // Récupérer la position et les dimensions du SVG
const rect = svgElement.getBoundingClientRect(); // const rect = svgElement.getBoundingClientRect();
const circleX = event.clientX - rect.left;
const circleY = event.clientY - rect.top;
// Afficher le popup avec le contenu spécifique // // Calculer la position relative du cercle
showPopup(content, circleX, circleY); // const circleX = event.clientX - rect.left;
// const circleY = event.clientY - rect.top;
// Empêcher la propagation de l'événement pour éviter la fermeture immédiate // // // Calculer la moitié du SVG
event.stopPropagation(); // // const svgHalfWidth = rect.width / 2;
// // // Déterminer si le cercle est sur la moitié gauche ou droite du SVG
// // const isLeftHalf = circleX < svgHalfWidth;
// Afficher le popup avec la position et l'alignement adaptés
showPopup(content);
}
// Gestion du changement de couleur sur le cercle
if (event.target.tagName === 'circle') {
event.target.setAttribute('fill', 'red');
} }
}); });
// Ferme le popup quand on clique n'importe où sur la page, sauf sur le popup // Fermer le popup lorsque la souris quitte le cercle
document.addEventListener('click', function(event) { svgElement.addEventListener('mouseout', function(event) {
// Vérifier si le clic s'est produit en dehors du popup if (event.target.classList.contains('site-link')) {
if (popup.style.display === 'block' && !popup.contains(event.target)) {
closePopup(); closePopup();
} }
// Réinitialiser la couleur du cercle au survol de la souris
if (event.target.tagName === 'circle') {
event.target.setAttribute('fill', 'black'); // Remettre en noir
}
}); });
// Mettre à jour la logique de calcul des positions
function recalculateSitePositions() {
const allSites = document.querySelectorAll('.site-link');
allSites.forEach((site, index) => {
const geofield = site.getAttribute('data-geofield'); // Assurez-vous que ces attributs sont bien définis
const lon = parseFloat(geofield.split(',')[0]);
const lat = parseFloat(geofield.split(',')[1]);
const x = round((lon - lonLeft) / (lonRight - lonLeft) * vp_w);
const y = round((latTop - lat) / (latTop - latBottom) * vp_h);
site.setAttribute('transform', `translate(${x}, ${y})`);
});
}
window.addEventListener('resize', function() {
recalculateSitePositions();
if (popup.style.display === 'block') {
const currentPopupRect = popup.getBoundingClientRect();
const rect = svgElement.getBoundingClientRect();
showPopup(popupContent.innerHTML, currentPopupRect.left - rect.left, currentPopupRect.top - rect.top);
}
});
// Gérer le clic ou le toucher des cercles
function handleCircleClick(content) {
showPopup(content, event.clientX, event.clientY, event.target.getAttribute('data-left-half') === 'true');
}
// Écouter les événements de clic et de toucher sur le SVG
svgElement.addEventListener('click', function(event) {
if (event.target.classList.contains('site-link') || event.target.tagName === 'rect') {
const content = event.target.getAttribute('data-content');
handleCircleClick(content);
}
});

View File

@ -1,7 +1,7 @@
sites_map_block: sites_map_block:
css: css:
theme: theme:
assets/css/fontface.css: {} assets/css/fontface.scss: {}
assets/css/carte-interactive-qdd.css: {} assets/css/carte-interactive-qdd.scss: {}
js: js:
assets/js/carte-interactive-qdd.js: {} assets/js/carte-interactive-qdd.js: {}

View File

@ -28,8 +28,8 @@ class SitesMap extends BlockBase {
$sites_paths = ""; $sites_paths = "";
$vp_w = 400; $vp_w = 600;
$vp_h = 400; $vp_h = 600;
// Coordonnées géographiques des coins de la carte (France) // Coordonnées géographiques des coins de la carte (France)
$latTop = 52.0; // Nord-Ouest (coin supérieur gauche) $latTop = 52.0; // Nord-Ouest (coin supérieur gauche)
@ -51,35 +51,37 @@ class SitesMap extends BlockBase {
$geofield = $site->get('field_geofield')->get(0); $geofield = $site->get('field_geofield')->get(0);
$lon = $geofield->lon; $lon = $geofield->lon;
$lat = $geofield->lat; $lat = $geofield->lat;
$geofieldData = "$lon,$lat"; // Utiliser une chaîne pour stocker la position
$x = round(($lon - $lonLeft) / ($lonRight - $lonLeft) * $vp_w); $x = round(($lon - $lonLeft) / ($lonRight - $lonLeft) * $vp_w);
$y = round(($latTop - $lat) / ($latTop - $latBottom) * $vp_h); $y = round(($latTop - $lat) / ($latTop - $latBottom) * $vp_h);
$r = 10; $r = 10;
$m = -$r+2; $m = -$r+4;
$l = $r*2-4; $l = $r*2-7;
$sites_paths .= <<<SVGSITEPATH $sites_paths .= <<<SVGSITEPATH
<g <g
id="site-$index" id="site-$index"
transform=" data-geofield="$geofieldData"
translate($x,$y)"> transform="translate($x,$y)"
<circle style="cursor: pointer;" <!-- Change le curseur pour indiquer l'interaction -->
id="path83" class="circle" >
cx="0" cy="0" r="$r" <rect width="10" height="10" transform="translate($x,$y)" fill="none" onclick="handleCircleClick('$datacontent')"></rect> <!-- Zone d'interaction invisible -->
style="fill:#000000;fill-opacity:1;fill-rule:nonzero;" />
<path
id="path84"
d="m 0,$m v $l"
style="fill:none;stroke:#ffffff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:10;stroke-dasharray:none;stroke-opacity:1" />
<path
id="path85"
d="m $m,0 h $l"
style="fill:none;stroke:#ffffff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:10;stroke-dasharray:none;stroke-opacity:1" />
<circle <circle
class="site-link" class="site-link"
data-content="$datacontent" data-content="$datacontent"
cx="0" cy="0" r="$r" cx="0" cy="0" r="$r"
style="fill:#000000;fill-opacity:0;fill-rule:nonzero;" /> style="fill-opacity:1;fill-rule:nonzero;" />
<path
id="path84"
d="m 0,$m v $l"
style="pointer-events: none;fill:none;stroke:#ffffff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:10;stroke-dasharray:none;stroke-opacity:1" />
<path
id="path85"
d="m $m,0 h $l"
style="pointer-events: none;fill:none;stroke:#ffffff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:10;stroke-dasharray:none;stroke-opacity:1" />
</g> </g>
SVGSITEPATH; SVGSITEPATH;
} }

View File

@ -3,9 +3,9 @@
<path {{ path_attributes }}></path> <path {{ path_attributes }}></path>
</svg> #} </svg> #}
<svg <svg
width="{{ vpw }}" width="100%"
height="{{ vph }}" height="auto"
viewBox="0 0 100% 400px" viewBox="0 0 {{ vpw }} {{ vph }}"
version="1.1" version="1.1"
id="svg1" id="svg1"
xmlns="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg"
@ -13,9 +13,11 @@
<g <g
id="layer1" id="layer1"
width="auto"
height="100%"
transform=" transform="
translate(-25.237685,-27.066503) translate(-34,-43)
scale(2 2)" scale(3 3)"
> >
<g <g
id="g87" id="g87"

File diff suppressed because one or more lines are too long

View File

@ -209,6 +209,10 @@ h2 {
} }
} }
.layout--threecol-25-50-25 {
width: 100vw;
}
/* Eric Meyer's Reset CSS v2.0 - http://cssreset.com */ /* Eric Meyer's Reset CSS v2.0 - http://cssreset.com */
ul { ul {
list-style-type: none; list-style-type: none;
@ -461,7 +465,7 @@ header .header:hover + .header_nav_container {
/* Taille définitive du header après l'animation */ /* Taille définitive du header après l'animation */
.header--collapsed { .header--collapsed {
height: 320px; /* Ou la hauteur que vous souhaitez pour votre header */ height: 320px; /* Ou la hauteur que vous souhaitez pour votre header */
width: 45%; width: 35%;
transform-origin: bottom right; transform-origin: bottom right;
transition: all 1s ease-in-out; transition: all 1s ease-in-out;
} }
@ -480,7 +484,7 @@ header .header:hover + .header_nav_container {
} }
} }
.header--collapsed .header_left_container { .header--collapsed .header_left_container {
flex: 0 0 50%; flex: 0 0 70%;
transform-origin: bottom right; transform-origin: bottom right;
} }
@media (max-width: 810px) { @media (max-width: 810px) {
@ -502,7 +506,7 @@ header .header:hover + .header_nav_container {
.header--collapsed-already { .header--collapsed-already {
height: 320px; /* Ou la hauteur que vous souhaitez pour votre header */ height: 320px; /* Ou la hauteur que vous souhaitez pour votre header */
width: 45%; width: 35%;
transform-origin: bottom right; transform-origin: bottom right;
transition: all 0s ease-in-out; transition: all 0s ease-in-out;
} }
@ -516,7 +520,7 @@ header .header:hover + .header_nav_container {
} }
} }
.header--collapsed-already .header_left_container { .header--collapsed-already .header_left_container {
flex: 0 0 50%; flex: 0 0 70%;
transform-origin: bottom right; transform-origin: bottom right;
} }
@media (max-width: 810px) { @media (max-width: 810px) {
@ -1636,13 +1640,13 @@ header #block-quartiers-de-demain-logoquartiersdedemain .field_field_logo .qdd-h
#home .config_pages--type--diaporama-home .diaporama .slick-list { #home .config_pages--type--diaporama-home .diaporama .slick-list {
padding: 0 !important; padding: 0 !important;
} }
#home .config_pages--type--diaporama-home .diaporama .slick-list .cadre-img-zoom { #home .config_pages--type--diaporama-home .diaporama .slick-list .slick-track {
max-height: 1281px; max-height: 1281px;
overflow: hidden; overflow: hidden;
} }
#home .config_pages--type--diaporama-home .diaporama .slick-list .cadre-img-zoom img { #home .config_pages--type--diaporama-home .diaporama .slick-list .slick-track img {
width: 100%; width: 100%;
height: 960px; height: auto;
object-fit: cover; object-fit: cover;
} }
#home .config_pages--type--diaporama-home .diaporama .slick-list blockquote { #home .config_pages--type--diaporama-home .diaporama .slick-list blockquote {
@ -1768,6 +1772,28 @@ header #block-quartiers-de-demain-logoquartiersdedemain .field_field_logo .qdd-h
font-family: "gilroy-bold"; font-family: "gilroy-bold";
padding-bottom: 1rem; padding-bottom: 1rem;
} }
#home article.node-type-static .field_field_map_block #block-sitesmapblock {
background-color: #cecfcc;
padding-top: 3rem;
padding-left: 4rem;
}
@media (max-width: 1090px) {
#home article.node-type-static .field_field_map_block #block-sitesmapblock {
padding-left: 0rem;
}
}
#home article.node-type-static .field_field_map_block #block-sitesmapblock h2 {
width: fit-content;
margin: auto;
font-size: 2rem;
padding-bottom: 2rem;
}
@media (max-width: 1090px) {
#home article.node-type-static .field_field_map_block #block-sitesmapblock h2 {
padding-bottom: 0rem;
font-size: 1.8rem;
}
}
#home article.node-type-static #paragraph-id--1 { #home article.node-type-static #paragraph-id--1 {
background-color: #edefe8; background-color: #edefe8;
position: relative; position: relative;
@ -2817,15 +2843,17 @@ header #block-quartiers-de-demain-logoquartiersdedemain .field_field_logo .qdd-h
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
} }
.node-type-site .layout--threecol-25-50-25 .layout__region--first .block-region-first {
width: 100%;
}
.node-type-site .layout--threecol-25-50-25 .layout__region--first .block-region-first .views-element-container { .node-type-site .layout--threecol-25-50-25 .layout__region--first .block-region-first .views-element-container {
margin-bottom: 3rem; margin-bottom: 3rem;
} }
.node-type-site .layout--threecol-25-50-25 .layout__region--first div { .node-type-site .layout--threecol-25-50-25 .layout__region--first div {
margin-bottom: 0.5rem; margin-bottom: 0.5rem;
} }
.node-type-site .layout--threecol-25-50-25 .layout__region--first div #sites-map-container {
position: fixed;
width: auto;
left: 1.3rem;
}
@media (max-width: 500px) { @media (max-width: 500px) {
.node-type-site .layout--threecol-25-50-25 .layout__region--first div:has(.field_field_documents) { .node-type-site .layout--threecol-25-50-25 .layout__region--first div:has(.field_field_documents) {
margin-top: 1rem; margin-top: 1rem;
@ -3045,3 +3073,105 @@ header #block-quartiers-de-demain-logoquartiersdedemain .field_field_logo .qdd-h
.node-type-site .layout--threecol-25-50-25 .layout__region--third .block-region-third div .next-site::before { .node-type-site .layout--threecol-25-50-25 .layout__region--third .block-region-third div .next-site::before {
content: url("../img/next.svg"); content: url("../img/next.svg");
} }
@font-face {
font-family: "gilroy-semibold";
src: url("../css/fonts/Gilroy/gilroy-semibold-webfont.woff") format("woff");
}
#sites-map-container {
background-color: #cecfcc;
text-align: center;
position: relative;
width: 100%; /* Prend toute la largeur du conteneur parent */
max-width: 800px; /* Optionnel : Limiter la largeur maximale */
margin: 0 auto; /* Centrer le conteneur */
height: auto; /* Permet à la hauteur de s'ajuster automatiquement */
}
@media (max-width: 810px) {
#sites-map-container {
width: 80%; /* Prend toute la largeur du conteneur parent */
}
}
@media (max-width: 530px) {
#sites-map-container {
width: 100%; /* Prend toute la largeur du conteneur parent */
height: 485px;
}
}
@media (max-width: 400px) {
#sites-map-container {
width: 100%; /* Prend toute la largeur du conteneur parent */
height: 430px;
}
}
/* Changer la couleur au survol (hover) */
#sites-map-container .site-link:hover {
cursor: pointer;
}
/* Styles du popup (caché par défaut) */
#sites-map-container #popup {
font-family: "gilroy-light";
display: none;
position: absolute;
z-index: 1000;
text-align: left;
padding-left: 1rem;
pointer-events: none;
}
@media (max-width: 1090px) {
#sites-map-container #popup {
bottom: 20px;
}
}
/* Position du popup à droite lorsque l'écran est plus grand que 1090px */
@media (min-width: 1090px) {
#sites-map-container #popup {
top: 50%; /* Centrer verticalement */
left: 80%; /* Placer le popup à droite de la carte */
transform: translateY(-50%); /* Ajuster pour centrer verticalement */
width: 300px;
}
}
#sites-map-container strong {
color: #f7002b;
font-family: "gilroy-bold";
}
#sites-map-container a {
display: none;
align-items: center;
color: white;
background: black;
text-transform: uppercase;
font-size: 0.8rem;
padding-left: 0.5rem;
text-decoration: none;
margin-top: 0.7rem;
height: 1.3rem;
}
#sites-map-container a:after {
display: inline-flex;
content: url("../img/noun-arrow-to-right.svg");
padding-right: 0.2rem;
padding-left: 0.2rem;
}
#popup-content {
width: 300px;
}
#popup-content p {
font-size: 0.7rem;
}
@media (max-width: 810px) {
#popup-content {
width: 300px;
background-color: white;
border-radius: 5px;
padding: 0.5rem;
padding-left: 1rem;
}
}

View File

@ -369,6 +369,8 @@
//////////// slideshow home ////////////////////////// //////////// slideshow home //////////////////////////
$(document).ready(function(){ $(document).ready(function(){
let actuview = $('.content-actus .view') let actuview = $('.content-actus .view')
if (actuview) { if (actuview) {
@ -400,6 +402,9 @@
console.log('salut slick home'); console.log('salut slick home');
} }
$('.slick-carousel').slick({
lazyLoad: 'progressive', // Option 'ondemand' ou 'progressive'
});
}); });
@ -415,11 +420,11 @@
slidesToShow: 1, slidesToShow: 1,
dots: false, dots: false,
arrows: false, arrows: false,
centerMode: true, // centerMode: true,
adaptiveHeight: false, adaptiveHeight: true,
autoplay: true, // Activer l'autoplay autoplay: true, // Activer l'autoplay
autoplaySpeed: 4000, // Changement de slide toutes les 4 secondes autoplaySpeed: 4000, // Changement de slide toutes les 4 secondes
infinite: true, // infinite: true,
pauseOnHover: false, // Ne pas arrêter l'autoplay lors du survol pauseOnHover: false, // Ne pas arrêter l'autoplay lors du survol
pauseOnFocus: false, pauseOnFocus: false,
responsive: [ responsive: [
@ -439,6 +444,26 @@
}); });
///////////// carte sticky node site ///////////////////
// window.addEventListener('scroll', function() {
// const mapContainer = document.getElementById('sites-map-container');
// const header = document.querySelector('header'); // Sélectionnez votre header
// const headerHeight = header.offsetHeight; // Calculer la hauteur du header
// const scrollPosition = window.scrollY; // Obtenir la position actuelle du scroll
// console.log('Hauteur dynamique du header:', headerHeight);
// if (scrollPosition >= headerHeight - 350 ) {
// mapContainer.classList.add('fixed');
// mapContainer.style.position = 'fixed';
// mapContainer.style.top = headerHeight + 350 ; // Fixé en haut une fois passé le header
// } else {
// mapContainer.classList.remove('fixed');
// mapContainer.style.position = 'static'; // Retour à la position initiale
// }
// });
})(jQuery, window); })(jQuery, window);

View File

@ -51,3 +51,6 @@ $width-menu-slidedown : 550px;
} }
} }
.layout--threecol-25-50-25{
width: 100vw;
}

View File

@ -7,12 +7,12 @@
.diaporama{ .diaporama{
.slick-list{ .slick-list{
padding: 0 !important; padding: 0 !important;
.cadre-img-zoom{ .slick-track{
max-height: 1281px; max-height: 1281px;
overflow:hidden; overflow:hidden;
img{ img{
width: 100%; width: 100%;
height: 960px; height: auto;
object-fit: cover; object-fit: cover;
// transform: scale(1.2); // transform: scale(1.2);
// // // animation: zoomOut infinite 4.3s ease-in-out; // // // animation: zoomOut infinite 4.3s ease-in-out;
@ -158,6 +158,28 @@
font-family: 'gilroy-bold'; font-family: 'gilroy-bold';
padding-bottom: 1rem; padding-bottom: 1rem;
} }
.field_field_map_block{
#block-sitesmapblock{
background-color: #cecfcc;
padding-top: 3rem;
padding-left: 4rem;
@media(max-width: 1090px){
padding-left: 0rem;
}
h2{
width: fit-content;
margin: auto;
font-size: 2rem;
padding-bottom: 2rem;
@media(max-width: 1090px){
padding-bottom: 0rem;
font-size: 1.8rem;
}
}
}
}
#paragraph-id--1{ ///// Les enjeux 1 #paragraph-id--1{ ///// Les enjeux 1
background-color: #edefe8; background-color: #edefe8;
position: relative; position: relative;

View File

@ -18,8 +18,9 @@
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
.block-region-first{ .block-region-first{
width: 100%;
.views-element-container{ .views-element-container{
margin-bottom: 3rem; margin-bottom: 3rem;
} }
@ -27,6 +28,15 @@
div{ div{
// width: fit-content; // width: fit-content;
margin-bottom: 0.5rem; margin-bottom: 0.5rem;
// #sites-map-container.fixed{
// width: auto;
// left: 1.3rem;
// }
#sites-map-container{
position: fixed;
width: auto;
left: 1.3rem;
}
} }
div:has(.field_field_documents){ div:has(.field_field_documents){
@media(max-width: 500px){ @media(max-width: 500px){

View File

@ -211,7 +211,7 @@ header{
/* Taille définitive du header après l'animation */ /* Taille définitive du header après l'animation */
.header--collapsed { .header--collapsed {
height: $header-height; /* Ou la hauteur que vous souhaitez pour votre header */ height: $header-height; /* Ou la hauteur que vous souhaitez pour votre header */
width: 45%; width: 35%;
transform-origin: bottom right; transform-origin: bottom right;
transition: all 1s ease-in-out; transition: all 1s ease-in-out;
@media(max-width: 1090px) { @media(max-width: 1090px) {
@ -225,7 +225,7 @@ header{
height: 170px; height: 170px;
} }
.header_left_container{ .header_left_container{
flex: 0 0 50%; flex: 0 0 70%;
transform-origin: bottom right; transform-origin: bottom right;
@media(max-width: 810px){ @media(max-width: 810px){
flex: 1 0 100%; flex: 1 0 100%;
@ -244,7 +244,7 @@ header{
} }
.header--collapsed-already{ .header--collapsed-already{
height: $header-height; /* Ou la hauteur que vous souhaitez pour votre header */ height: $header-height; /* Ou la hauteur que vous souhaitez pour votre header */
width: 45%; width: 35%;
transform-origin: bottom right; transform-origin: bottom right;
transition: all 0s ease-in-out; transition: all 0s ease-in-out;
.qdd-header{ .qdd-header{
@ -255,7 +255,7 @@ header{
height: 170px; height: 170px;
} }
.header_left_container{ .header_left_container{
flex: 0 0 50%; flex: 0 0 70%;
transform-origin: bottom right; transform-origin: bottom right;
@media(max-width: 810px){ @media(max-width: 810px){
flex: 1 0 100%; flex: 1 0 100%;

View File

@ -47,3 +47,5 @@
@import "pages/actualite"; @import "pages/actualite";
@import "pages/node-type-site"; @import "pages/node-type-site";
@import "/home/ouidade/Developer/docker-quartiersdedemain/src/web/modules/custom/q2d_mod/assets/css/carte-interactive-qdd.scss";