From 7b41525b69af0e55b3493b29808845c8f5c76826 Mon Sep 17 00:00:00 2001 From: farhan-shafi Date: Sat, 6 Jul 2024 11:57:09 +0500 Subject: [PATCH] fix content toggle performance issue --- readme.txt | 1 + src/blocks/content-toggle/front.build.js | 34 ++++++++++----- src/blocks/content-toggle/front.js | 53 ++++++++++++------------ 3 files changed, 52 insertions(+), 36 deletions(-) diff --git a/readme.txt b/readme.txt index 2bc61251..4d2638f3 100644 --- a/readme.txt +++ b/readme.txt @@ -152,6 +152,7 @@ That's it. You're done! = 3.2.1 = +* FIX: Content Toggle performance issue. * FIX: Post Excerpt null warning in post grid block. * FIX: Post image preserve aspect ratio not working properly on frontend. * IMPROVE: Run counter when it visible on the screen in the counter block. diff --git a/src/blocks/content-toggle/front.build.js b/src/blocks/content-toggle/front.build.js index ad91dc62..ffb8deeb 100644 --- a/src/blocks/content-toggle/front.build.js +++ b/src/blocks/content-toggle/front.build.js @@ -51,11 +51,9 @@ var togglePanel = function togglePanel(target) { if (panelContent.classList.contains("ub-hiding")) { var convertedTop = convertToPixels(topPadding, topPaddingUnit); var convertedBottom = convertToPixels(bottomPadding, bottomPaddingUnit); - panelContent.style.height = "".concat(panelContent.scrollHeight + convertedTop + convertedBottom - (topPaddingUnit === "%" || bottomPaddingUnit === "%" ? panelContent.parentElement.scrollHeight : 0), "px"); - Object.assign(panelContent.style, { - paddingTop: "".concat(convertedTop, "px"), - paddingBottom: "".concat(convertedBottom, "px") - }); + panelContent.style.height = "".concat(panelContent.scrollHeight + convertedTop + convertedBottom, "px"); + panelContent.style.paddingTop = "".concat(convertedTop, "px"); + panelContent.style.paddingBottom = "".concat(convertedBottom, "px"); document.querySelectorAll(".ub_image_slider").forEach(function (slider) { new Swiper("#".concat(slider.id), JSON.parse(slider.dataset.swiperData)); }); @@ -82,6 +80,24 @@ var togglePanel = function togglePanel(target) { embeddedContent.style.removeProperty("height"); }); }; +var handleKeyDown = function handleKeyDown(e, i, toggleHeads) { + if (e.key === "ArrowUp" && i > 0) { + e.preventDefault(); + toggleHeads[i - 1].focus(); + } else if (e.key === "ArrowDown" && i < toggleHeads.length - 1) { + e.preventDefault(); + toggleHeads[i + 1].focus(); + } else if ([" ", "Enter"].includes(e.key)) { + e.preventDefault(); + togglePanel(e.currentTarget); + } else if (e.key === "Home" && i > 0) { + e.preventDefault(); + toggleHeads[0].focus(); + } else if (e.key === "End" && i < toggleHeads.length - 1) { + e.preventDefault(); + toggleHeads[toggleHeads.length - 1].focus(); + } +}; var attachTogglePanelEvents = function attachTogglePanelEvents() { document.querySelectorAll(".wp-block-ub-content-toggle").forEach(function (toggleContainer) { var toggleHeads = Array.from(toggleContainer.children).map(function (toggle) { @@ -90,12 +106,9 @@ var attachTogglePanelEvents = function attachTogglePanelEvents() { return toggle && toggle.classList.contains("wp-block-ub-content-toggle-accordion-title-wrap"); }); toggleHeads.forEach(function (toggleHead, i) { + toggleHead.removeEventListener("keydown", handleKeyDown); toggleHead.addEventListener("keydown", function (e) { - if (e.key === "ArrowUp" && i > 0) e.preventDefault(), toggleHeads[i - 1].focus(); - if (e.key === "ArrowDown" && i < toggleHeads.length - 1) e.preventDefault(), toggleHeads[i + 1].focus(); - if ([" ", "Enter"].includes(e.key)) e.preventDefault(), togglePanel(toggleHead); - if (e.key === "Home" && i > 0) e.preventDefault(), toggleHeads[0].focus(); - if (e.key === "End" && i < toggleHeads.length - 1) e.preventDefault(), toggleHeads[toggleHeads.length - 1].focus(); + return handleKeyDown(e, i, toggleHeads); }); }); if (!toggleContainer.hasAttribute("data-preventcollapse")) { @@ -119,6 +132,7 @@ var attachTogglePanelEvents = function attachTogglePanelEvents() { var panelId = instance.parentElement.getAttribute("id"); var hash = location.hash.substring(1); if (panelId && panelId === hash) togglePanel(instance); + instance.removeEventListener("click", togglePanel); instance.addEventListener("click", function (e) { e.stopImmediatePropagation(); togglePanel(instance); diff --git a/src/blocks/content-toggle/front.js b/src/blocks/content-toggle/front.js index 2c261f04..897d0645 100644 --- a/src/blocks/content-toggle/front.js +++ b/src/blocks/content-toggle/front.js @@ -64,19 +64,9 @@ const togglePanel = (target) => { const convertedTop = convertToPixels(topPadding, topPaddingUnit); const convertedBottom = convertToPixels(bottomPadding, bottomPaddingUnit); - panelContent.style.height = `${ - panelContent.scrollHeight + - convertedTop + - convertedBottom - - (topPaddingUnit === "%" || bottomPaddingUnit === "%" - ? panelContent.parentElement.scrollHeight - : 0) - }px`; - - Object.assign(panelContent.style, { - paddingTop: `${convertedTop}px`, - paddingBottom: `${convertedBottom}px`, - }); + panelContent.style.height = `${panelContent.scrollHeight + convertedTop + convertedBottom}px`; + panelContent.style.paddingTop = `${convertedTop}px`; + panelContent.style.paddingBottom = `${convertedBottom}px`; document.querySelectorAll(".ub_image_slider").forEach((slider) => { new Swiper(`#${slider.id}`, JSON.parse(slider.dataset.swiperData)); @@ -110,6 +100,25 @@ const togglePanel = (target) => { }); }; +const handleKeyDown = (e, i, toggleHeads) => { + if (e.key === "ArrowUp" && i > 0) { + e.preventDefault(); + toggleHeads[i - 1].focus(); + } else if (e.key === "ArrowDown" && i < toggleHeads.length - 1) { + e.preventDefault(); + toggleHeads[i + 1].focus(); + } else if ([" ", "Enter"].includes(e.key)) { + e.preventDefault(); + togglePanel(e.currentTarget); + } else if (e.key === "Home" && i > 0) { + e.preventDefault(); + toggleHeads[0].focus(); + } else if (e.key === "End" && i < toggleHeads.length - 1) { + e.preventDefault(); + toggleHeads[toggleHeads.length - 1].focus(); + } +}; + const attachTogglePanelEvents = () => { document .querySelectorAll(".wp-block-ub-content-toggle") @@ -125,18 +134,10 @@ const attachTogglePanelEvents = () => { ); toggleHeads.forEach((toggleHead, i) => { - toggleHead.addEventListener("keydown", (e) => { - if (e.key === "ArrowUp" && i > 0) - e.preventDefault(), toggleHeads[i - 1].focus(); - if (e.key === "ArrowDown" && i < toggleHeads.length - 1) - e.preventDefault(), toggleHeads[i + 1].focus(); - if ([" ", "Enter"].includes(e.key)) - e.preventDefault(), togglePanel(toggleHead); - if (e.key === "Home" && i > 0) - e.preventDefault(), toggleHeads[0].focus(); - if (e.key === "End" && i < toggleHeads.length - 1) - e.preventDefault(), toggleHeads[toggleHeads.length - 1].focus(); - }); + toggleHead.removeEventListener("keydown", handleKeyDown); + toggleHead.addEventListener("keydown", (e) => + handleKeyDown(e, i, toggleHeads), + ); }); if (!toggleContainer.hasAttribute("data-preventcollapse")) { @@ -177,6 +178,7 @@ const attachTogglePanelEvents = () => { const hash = location.hash.substring(1); if (panelId && panelId === hash) togglePanel(instance); + instance.removeEventListener("click", togglePanel); instance.addEventListener("click", (e) => { e.stopImmediatePropagation(); togglePanel(instance); @@ -219,7 +221,6 @@ document.addEventListener("DOMContentLoaded", () => { ) { Array.from(toggleContainer.children).forEach((child) => { const panel = child.children[0].nextElementSibling; - if (!panel.classList.contains("ub-hide")) { togglePanel(child.children[0]); }