annule max-height presentation en js
This commit is contained in:
@@ -485,79 +485,76 @@ $(document).ready(function () {
|
||||
|
||||
/////////////////// start voir plus... actualite dans /actualites & /home ////////////////////
|
||||
|
||||
if ($("#actualites").length > 0 || $("#home").length > 0) {
|
||||
$(".node-type-actualite").each(function () {
|
||||
let article = $(this);
|
||||
if ($("#actualites" ).length > 0 || $("#home").length > 0) {
|
||||
$(".node-type-actualite").each(function () {
|
||||
let article = $(this);
|
||||
|
||||
let body = article.find(".field_body");
|
||||
let links = article.find(".field_field_liens");
|
||||
let body = article.find(".field_body");
|
||||
let links = article.find(".field_field_liens");
|
||||
|
||||
body.hide();
|
||||
links.hide();
|
||||
body.hide();
|
||||
links.hide();
|
||||
|
||||
let toggleButton = $("<button>")
|
||||
.addClass("toggle-actualite")
|
||||
.insertAfter(article);
|
||||
let toggleButton = $("<button>")
|
||||
.addClass("toggle-actualite")
|
||||
.insertAfter(article);
|
||||
|
||||
// Fonction commune
|
||||
function toggleActu () {
|
||||
body.slideToggle();
|
||||
links.slideToggle();
|
||||
toggleButton.toggleClass("open");
|
||||
}
|
||||
toggleButton.on("click", function () {
|
||||
body.slideToggle();
|
||||
links.slideToggle();
|
||||
$(this).toggleClass("open");
|
||||
});
|
||||
|
||||
// Clic sur la flèche
|
||||
toggleButton.on("click", function (e) {
|
||||
e.stopPropagation(); // évite des conflits éventuels
|
||||
toggleActu();
|
||||
});
|
||||
|
||||
// Clic sur la flèche
|
||||
toggleButton.on("click", function (e) {
|
||||
e.stopPropagation();
|
||||
toggleActu();
|
||||
// Clic n'importe où sur le node
|
||||
article.on("click", function (e) {
|
||||
// Optionnel : ne pas toggle si on clique sur un lien
|
||||
if ($(e.target).closest("a").length) {
|
||||
return;
|
||||
}
|
||||
toggleActu();
|
||||
});
|
||||
});
|
||||
|
||||
// Clic n'importe où sur le node
|
||||
article.on("click", function (e) {
|
||||
// Ne rien faire si clic sur un lien
|
||||
if ($(e.target).closest("a").length) {
|
||||
return;
|
||||
// slimselect
|
||||
// duplicated due to embeded view (archives)
|
||||
let actu_type_select = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
toggleActu();
|
||||
});
|
||||
});
|
||||
|
||||
// slimselect
|
||||
// duplicated due to embeded view (archives)
|
||||
let actu_type_select = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_type_select2 = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select2 = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
let actu_type_select2 = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select2 = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
/////////////////// end voir plus... actualite dans /actualites & /home ////////////////////
|
||||
|
||||
|
||||
|
||||
/////////////// start class à view-rows-ressources ////////
|
||||
|
||||
$(".view-rows-wrapper").each(function () {
|
||||
@@ -605,74 +602,35 @@ document.addEventListener('DOMContentLoaded', function () {
|
||||
|
||||
if (!pres) return;
|
||||
|
||||
// On s’assure que le bloc est animé via max-height
|
||||
pres.style.overflow = 'hidden';
|
||||
pres.style.maxHeight = '0px';
|
||||
|
||||
// Création du bouton
|
||||
const btn = document.createElement('button');
|
||||
btn.className = 'btn-equipe-toggle';
|
||||
btn.textContent = "EN SAVOIR PLUS SUR L'ÉQUIPE";
|
||||
btn.setAttribute('aria-expanded', 'false');
|
||||
btn.setAttribute('aria-expanded', false);
|
||||
|
||||
// Insertion du bouton juste après le bloc présentation
|
||||
pres.insertAdjacentElement('afterend', btn);
|
||||
|
||||
// Ligne de séparation après le bouton
|
||||
const separator = document.createElement('div');
|
||||
separator.className = 'equipe-separator';
|
||||
btn.insertAdjacentElement('afterend', separator);
|
||||
|
||||
function openPanel() {
|
||||
pres.classList.add('is-open');
|
||||
if (photo) photo.classList.add('is-open');
|
||||
|
||||
// On force le navigateur à appliquer la classe avant de mesurer
|
||||
requestAnimationFrame(() => {
|
||||
// S’assurer que le bloc n’est pas en display:none via le CSS
|
||||
// Si tu veux être ultra safe :
|
||||
pres.style.maxHeight = 'none'; // on enlève l’ancienne contrainte
|
||||
const h = pres.scrollHeight; // hauteur réelle du contenu
|
||||
pres.style.maxHeight = '0px'; // on repart de 0 pour l’animation
|
||||
|
||||
requestAnimationFrame(() => {
|
||||
pres.style.maxHeight = h + 'px';
|
||||
});
|
||||
});
|
||||
|
||||
btn.textContent = "FERMER LA PRÉSENTATION DE L'ÉQUIPE";
|
||||
btn.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
|
||||
function closePanel() {
|
||||
// Hauteur actuelle (contenu visible)
|
||||
const h = pres.scrollHeight;
|
||||
pres.style.maxHeight = h + 'px';
|
||||
|
||||
requestAnimationFrame(() => {
|
||||
pres.style.maxHeight = '0px';
|
||||
pres.classList.remove('is-open');
|
||||
if (photo) photo.classList.remove('is-open');
|
||||
});
|
||||
|
||||
btn.textContent = "EN SAVOIR PLUS SUR L'ÉQUIPE";
|
||||
btn.setAttribute('aria-expanded', 'false');
|
||||
}
|
||||
// 3. Ajout de la ligne après le bouton
|
||||
const separator = document.createElement('div');
|
||||
separator.className = 'equipe-separator';
|
||||
btn.insertAdjacentElement('afterend', separator);
|
||||
|
||||
// Toggle
|
||||
btn.addEventListener('click', function () {
|
||||
const isOpen = btn.getAttribute('aria-expanded') === 'true';
|
||||
const isOpen = pres.classList.toggle('is-open');
|
||||
|
||||
if (isOpen) {
|
||||
closePanel();
|
||||
} else {
|
||||
openPanel();
|
||||
}
|
||||
if (photo) photo.classList.toggle('is-open');
|
||||
|
||||
btn.textContent = isOpen
|
||||
? "FERMER LA PRÉSENTATION DE L'ÉQUIPE"
|
||||
: "EN SAVOIR PLUS SUR L'ÉQUIPE";
|
||||
|
||||
btn.setAttribute('aria-expanded', isOpen);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
|
||||
//////////////end toggle page node projet //////////////////
|
||||
|
||||
|
||||
|
||||
File diff suppressed because one or more lines are too long
@@ -4478,6 +4478,7 @@ body {
|
||||
}
|
||||
.node-type-projet .layout--threecol-25-50-25 .layout__region--second .block-region-second .field_field_equipe_photo.is-open,
|
||||
.node-type-projet .layout--threecol-25-50-25 .layout__region--second .block-region-second .field_field_equipe_presentation.is-open {
|
||||
max-height: 1500px;
|
||||
opacity: 1;
|
||||
}
|
||||
.node-type-projet .layout--threecol-25-50-25 .layout__region--second .block-region-second .btn-equipe-toggle {
|
||||
|
||||
@@ -427,79 +427,76 @@ $(document).ready(function () {
|
||||
|
||||
/////////////////// start voir plus... actualite dans /actualites & /home ////////////////////
|
||||
|
||||
if ($("#actualites").length > 0 || $("#home").length > 0) {
|
||||
$(".node-type-actualite").each(function () {
|
||||
let article = $(this);
|
||||
if ($("#actualites" ).length > 0 || $("#home").length > 0) {
|
||||
$(".node-type-actualite").each(function () {
|
||||
let article = $(this);
|
||||
|
||||
let body = article.find(".field_body");
|
||||
let links = article.find(".field_field_liens");
|
||||
let body = article.find(".field_body");
|
||||
let links = article.find(".field_field_liens");
|
||||
|
||||
body.hide();
|
||||
links.hide();
|
||||
body.hide();
|
||||
links.hide();
|
||||
|
||||
let toggleButton = $("<button>")
|
||||
.addClass("toggle-actualite")
|
||||
.insertAfter(article);
|
||||
let toggleButton = $("<button>")
|
||||
.addClass("toggle-actualite")
|
||||
.insertAfter(article);
|
||||
|
||||
// Fonction commune
|
||||
function toggleActu () {
|
||||
body.slideToggle();
|
||||
links.slideToggle();
|
||||
toggleButton.toggleClass("open");
|
||||
}
|
||||
toggleButton.on("click", function () {
|
||||
body.slideToggle();
|
||||
links.slideToggle();
|
||||
$(this).toggleClass("open");
|
||||
});
|
||||
|
||||
// Clic sur la flèche
|
||||
toggleButton.on("click", function (e) {
|
||||
e.stopPropagation(); // évite des conflits éventuels
|
||||
toggleActu();
|
||||
});
|
||||
|
||||
// Clic sur la flèche
|
||||
toggleButton.on("click", function (e) {
|
||||
e.stopPropagation();
|
||||
toggleActu();
|
||||
// Clic n'importe où sur le node
|
||||
article.on("click", function (e) {
|
||||
// Optionnel : ne pas toggle si on clique sur un lien
|
||||
if ($(e.target).closest("a").length) {
|
||||
return;
|
||||
}
|
||||
toggleActu();
|
||||
});
|
||||
});
|
||||
|
||||
// Clic n'importe où sur le node
|
||||
article.on("click", function (e) {
|
||||
// Ne rien faire si clic sur un lien
|
||||
if ($(e.target).closest("a").length) {
|
||||
return;
|
||||
// slimselect
|
||||
// duplicated due to embeded view (archives)
|
||||
let actu_type_select = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
toggleActu();
|
||||
});
|
||||
});
|
||||
|
||||
// slimselect
|
||||
// duplicated due to embeded view (archives)
|
||||
let actu_type_select = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_type_select2 = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select2 = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
}
|
||||
})
|
||||
let actu_type_select2 = new SlimSelect({
|
||||
select: '#edit-field-type-d-actualite-target-id--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--2',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
let actu_site_select2 = new SlimSelect({
|
||||
select: '#edit-field-site-target-id-verf--3',
|
||||
settings:{
|
||||
placeholderText: 'choisir',
|
||||
searchPlaceholder: 'choisir'
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
/////////////////// end voir plus... actualite dans /actualites & /home ////////////////////
|
||||
|
||||
|
||||
|
||||
/////////////// start class à view-rows-ressources ////////
|
||||
|
||||
$(".view-rows-wrapper").each(function () {
|
||||
@@ -547,74 +544,35 @@ document.addEventListener('DOMContentLoaded', function () {
|
||||
|
||||
if (!pres) return;
|
||||
|
||||
// On s’assure que le bloc est animé via max-height
|
||||
pres.style.overflow = 'hidden';
|
||||
pres.style.maxHeight = '0px';
|
||||
|
||||
// Création du bouton
|
||||
const btn = document.createElement('button');
|
||||
btn.className = 'btn-equipe-toggle';
|
||||
btn.textContent = "EN SAVOIR PLUS SUR L'ÉQUIPE";
|
||||
btn.setAttribute('aria-expanded', 'false');
|
||||
btn.setAttribute('aria-expanded', false);
|
||||
|
||||
// Insertion du bouton juste après le bloc présentation
|
||||
pres.insertAdjacentElement('afterend', btn);
|
||||
|
||||
// Ligne de séparation après le bouton
|
||||
const separator = document.createElement('div');
|
||||
separator.className = 'equipe-separator';
|
||||
btn.insertAdjacentElement('afterend', separator);
|
||||
|
||||
function openPanel() {
|
||||
pres.classList.add('is-open');
|
||||
if (photo) photo.classList.add('is-open');
|
||||
|
||||
// On force le navigateur à appliquer la classe avant de mesurer
|
||||
requestAnimationFrame(() => {
|
||||
// S’assurer que le bloc n’est pas en display:none via le CSS
|
||||
// Si tu veux être ultra safe :
|
||||
pres.style.maxHeight = 'none'; // on enlève l’ancienne contrainte
|
||||
const h = pres.scrollHeight; // hauteur réelle du contenu
|
||||
pres.style.maxHeight = '0px'; // on repart de 0 pour l’animation
|
||||
|
||||
requestAnimationFrame(() => {
|
||||
pres.style.maxHeight = h + 'px';
|
||||
});
|
||||
});
|
||||
|
||||
btn.textContent = "FERMER LA PRÉSENTATION DE L'ÉQUIPE";
|
||||
btn.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
|
||||
function closePanel() {
|
||||
// Hauteur actuelle (contenu visible)
|
||||
const h = pres.scrollHeight;
|
||||
pres.style.maxHeight = h + 'px';
|
||||
|
||||
requestAnimationFrame(() => {
|
||||
pres.style.maxHeight = '0px';
|
||||
pres.classList.remove('is-open');
|
||||
if (photo) photo.classList.remove('is-open');
|
||||
});
|
||||
|
||||
btn.textContent = "EN SAVOIR PLUS SUR L'ÉQUIPE";
|
||||
btn.setAttribute('aria-expanded', 'false');
|
||||
}
|
||||
// 3. Ajout de la ligne après le bouton
|
||||
const separator = document.createElement('div');
|
||||
separator.className = 'equipe-separator';
|
||||
btn.insertAdjacentElement('afterend', separator);
|
||||
|
||||
// Toggle
|
||||
btn.addEventListener('click', function () {
|
||||
const isOpen = btn.getAttribute('aria-expanded') === 'true';
|
||||
const isOpen = pres.classList.toggle('is-open');
|
||||
|
||||
if (isOpen) {
|
||||
closePanel();
|
||||
} else {
|
||||
openPanel();
|
||||
}
|
||||
if (photo) photo.classList.toggle('is-open');
|
||||
|
||||
btn.textContent = isOpen
|
||||
? "FERMER LA PRÉSENTATION DE L'ÉQUIPE"
|
||||
: "EN SAVOIR PLUS SUR L'ÉQUIPE";
|
||||
|
||||
btn.setAttribute('aria-expanded', isOpen);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
|
||||
//////////////end toggle page node projet //////////////////
|
||||
|
||||
|
||||
|
||||
@@ -207,7 +207,7 @@
|
||||
|
||||
.field_field_equipe_photo.is-open,
|
||||
.field_field_equipe_presentation.is-open {
|
||||
// max-height: 1500px;
|
||||
max-height: 1500px;
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user