• therearefivethings@lemmy.world
    link
    fedilink
    English
    arrow-up
    3
    ·
    1 year ago

    Just to make your pain a little less…

    function collapseNestedDivs(element) {
      const childDivs = element.querySelectorAll('div');
    
      childDivs.forEach((div) => {
        collapseNestedDivs(div); // Recursively check for nested divs
    
        if (div.childElementCount === 1 && div.children[0].tagName === 'DIV') {
          const nestedDiv = div.children[0];
          const parent = div.parentNode;
    
          // Move the styles from the nested div to the parent div
          Array.from(nestedDiv.style).forEach((styleName) => {
            parent.style[styleName] = nestedDiv.style[styleName];
          });
    
          // Move the classes from the nested div to the parent div
          nestedDiv.classList.forEach((className) => {
            parent.classList.add(className);
          });
    
          // Remove the nested div
          parent.removeChild(nestedDiv);
        }
      });
    }
    
    // Call the function to collapse the nested divs starting from a root element
    const rootElement = document.getElementById('root'); // Replace 'root' with your actual root element ID
    collapseNestedDivs(rootElement);
    
    
    • somefool@lemmy.world
      link
      fedilink
      English
      arrow-up
      2
      ·
      edit-2
      1 year ago

      My condolences. I’m having war flashbacks of working on an early 2000 website where the owner had repeatedly mashed “center” to try and get centered text in table cells. In every cell. 100+ center tags.