YOPU helper

A script for printing scores and playing scores on Yupu.co

// ==UserScript==
// @name         YOPU helper
// @namespace    http://tampermonkey.net/
// @version      0.1.4
// @description  A script for printing scores and playing scores on Yupu.co
// @author       ChenMo
// @Github       https://github.com/Chenmo1212/Yopu-Helper
// @match        https://yopu.co/view/*
// @icon         
// @run-at       document-end
// @grant        none
// @require      https://unpkg.com/[email protected]/dist/print.js
// @license MIT
// ==/UserScript==

(function () {
  'use strict';

  // Package print function
  const print = {
    chordScore: (printPage) => {
      printPage.setAttribute('id', 'print-content');
      printPage.style.height = 'auto';

      // Add padding to prevent unprinted content
      const tempPaddingDiv = document.createElement("div");
      tempPaddingDiv.style.height = "500px";
      printPage.append(tempPaddingDiv);

      printJS({ printable: 'print-content', type: 'html', header: 'PrintJS - Form Element Selection' });

      setTimeout(() => {
        tempPaddingDiv.remove();
      }, 3000);
    },
    tablature: (printPage) => {
      alert("Please refresh the page after printing.");

      const elementsToRemove = ['header', '.side', '.player-panel', '.print-sheet'];
      elementsToRemove.forEach((el) => {
        const element = document.querySelector(el);
        if (element) {
          element.remove();
        }
      });

      const noPrintElements = document.querySelectorAll(".no-print");
      noPrintElements.forEach((el) => {
        el.classList.remove("no-print");
        el.classList.add("print");
      });

      const body = document.body;
      body.style.width = "100%";
      body.style.padding = "0";
      body.style.overflow = "auto";

      printPage.style.overflow = "auto";

      const main = document.querySelector(".main");
      main.style.width = "100%";
      main.style.height = "100%";
      main.style.overflow = "auto";

      const layout = document.querySelector(".layout");
      layout.style.margin = "0";
      layout.style.width = "auto";

      window.print();
    }
  };

  // clear all timers
  const clearAllTimer = () => {
    const latestTid = setTimeout(() => {});

    for (let i = 0; i <= latestTid; i++) {
      clearTimeout(i);
      clearInterval(i);
    }
  };

  // Handling function for clicking the print button
  const handlePrintBtnClick = () => {
    const printPage = document.querySelector(".at-surface");
    const sheetContainer = document.querySelector(".sheet-container");

    if (!printPage) {
      print.tablature(sheetContainer);
    } else {
      print.chordScore(printPage);
    }
  };

  window.onload = () => {
    const btnGroup = document.querySelector('.control');
    const originPlayBtn = document.querySelector(".accent");

    // Handling function for clicking the play button
    const handlePlayBtnClick = () => {
      originPlayBtn.click();

      setTimeout(() => {
        clearAllTimer();
      }, 3000);
    };

    // Create a print button
    const newPrintBtn = document.createElement("div");
    newPrintBtn.className = "button-container svelte-8xk2fn";
    newPrintBtn.innerHTML = `<button size='big' theme='white' type='button' class='svelte-14csrjh block'>🖨️ &nbsp; Print</button>`;
    btnGroup.append(newPrintBtn);
    newPrintBtn.onclick = handlePrintBtnClick;

    // Create play button
    const newPlayBtn = document.createElement("div");
    newPlayBtn.className = "button-container svelte-120uqgv";
    newPlayBtn.innerHTML = `<button size='big' theme='white' type='button' class='svelte-14csrjh block'>🎵 &nbsp; Play</button>`;
    btnGroup.append(newPlayBtn);
    newPlayBtn.onclick = handlePlayBtnClick;
  }
})();