From a141dd5ce06f600edca6d073fd0d307cbe9aa3b0 Mon Sep 17 00:00:00 2001 From: Cory Dransfeldt Date: Sat, 19 Oct 2024 21:36:51 -0700 Subject: [PATCH] chore: search cleanup --- package-lock.json | 4 +- package.json | 2 +- src/assets/scripts/index.js | 137 ++++++++++++++++++++++++++++++------ 3 files changed, 118 insertions(+), 25 deletions(-) diff --git a/package-lock.json b/package-lock.json index e1427d18..09add7a1 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "coryd.dev", - "version": "1.5.19", + "version": "1.5.20", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "coryd.dev", - "version": "1.5.19", + "version": "1.5.20", "license": "MIT", "dependencies": { "@cdransf/api-text": "^1.5.0", diff --git a/package.json b/package.json index 54ebcbe2..63fb121e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "coryd.dev", - "version": "1.5.19", + "version": "1.5.20", "description": "The source for my personal site. Built using 11ty (and other tools).", "type": "module", "engines": { diff --git a/src/assets/scripts/index.js b/src/assets/scripts/index.js index 8c25e6a0..a88e1e34 100644 --- a/src/assets/scripts/index.js +++ b/src/assets/scripts/index.js @@ -1,4 +1,96 @@ window.addEventListener("load", () => { + // menu keyboard controls + (() => { + const menuInput = document.getElementById("menu-toggle"); + const menuButtonContainer = document.querySelector( + ".menu-button-container" + ); + const menuItems = document.querySelectorAll(".menu-primary li"); + + menuButtonContainer.addEventListener("keydown", (e) => { + if (e.key === "Enter" || e.key === " ") { + e.preventDefault(); + menuInput.checked = !menuInput.checked; + } + }); + + menuItems.forEach((item) => { + item.addEventListener("keydown", (e) => { + if (e.key === "Enter" || e.key === " ") { + e.preventDefault(); + item.querySelector("a").click(); + } + }); + }); + + document.addEventListener("keydown", (e) => { + if (e.key === "Escape" && menuInput.checked) menuInput.checked = false; + }); + })(); + + // modal keyboard controls and scroll management + (() => { + const modalInputs = document.querySelectorAll(".modal-input"); + if (!modalInputs) return; + + const toggleBodyScroll = (disableScroll) => { + if (disableScroll) { + document.body.style.overflow = "hidden"; + } else { + document.body.style.overflow = ""; + } + }; + + const checkModals = () => { + let isAnyModalOpen = false; + modalInputs.forEach((modalInput) => { + if (modalInput.checked) isAnyModalOpen = true; + }); + toggleBodyScroll(isAnyModalOpen); + }; + + modalInputs.forEach((modalInput) => { + modalInput.addEventListener("change", checkModals); + }); + + document.addEventListener("keydown", (e) => { + if (e.key === "Escape") { + modalInputs.forEach((modalInput) => { + if (modalInput.checked) modalInput.checked = false; + }); + toggleBodyScroll(false); + } + }); + + checkModals(); + })(); + + // text toggle for media pages + (() => { + const button = document.querySelector("[data-toggle-button]"); + const content = document.querySelector("[data-toggle-content]"); + const text = document.querySelectorAll("[data-toggle-content] p"); + const minHeight = 500; // this needs to match the height set on [data-toggle-content].text-toggle-hidden in text-toggle.css + const interiorHeight = Array.from(text).reduce( + (acc, node) => acc + node.scrollHeight, + 0 + ); + + if (!button || !content || !text) return; + + if (interiorHeight < minHeight) { + content.classList.remove("text-toggle-hidden"); + button.style.display = "none"; + return; + } + + button.addEventListener("click", () => { + const isHidden = content.classList.toggle("text-toggle-hidden"); + button.textContent = isHidden ? "Show more" : "Show less"; + }); + })(); + + // search logic (() => { if (typeof MiniSearch === "undefined") return; @@ -39,6 +131,7 @@ window.addEventListener("load", () => { let currentPage = 1; let currentResults = []; let total = 0; + let debounceTimeout; // Declare debounceTimeout here const parseMarkdown = (markdown) => markdown @@ -68,17 +161,17 @@ window.addEventListener("load", () => { const resultHTML = results .map( ({ title, url, description, type, total_plays }) => ` -
  • - -

    ${ - type === "artist" && total_plays - ? formatArtistTitle(title, total_plays) - : title - }

    -
    -

    ${truncateDescription(description)}

    -
  • - ` +
  • + +

    ${ + type === "artist" && total_plays + ? formatArtistTitle(title, total_plays) + : title + }

    +
    +

    ${truncateDescription(description)}

    +
  • + ` ) .join(""); @@ -129,17 +222,17 @@ window.addEventListener("load", () => { const newResultsHTML = results .map( ({ title, url, description, type, total_plays }) => ` -
  • - -

    ${ - type === "artist" && total_plays - ? formatArtistTitle(title, total_plays) - : title - }

    -
    -

    ${truncateDescription(description)}

    -
  • - ` +
  • + +

    ${ + type === "artist" && total_plays + ? formatArtistTitle(title, total_plays) + : title + }

    +
    +

    ${truncateDescription(description)}

    +
  • + ` ) .join(""); $results.insertAdjacentHTML("beforeend", newResultsHTML);