scratch block palate horizontal style

none

当前为 2025-01-26 提交的版本,查看 最新版本

// ==UserScript==
// @name         scratch block palate horizontal style
// @version      1
// @description  none
// @run-at       document-start
// @author       rssaromeo
// @license      GPLv3
// @tag          style
// @match        *://scratch.mit.edu/*
// @match        *://turbowarp.org/*
// @icon         
// @grant        none
// @namespace https://greasyforks.org/users/1184528
// ==/UserScript==
// fix when entering editor call setup
;(async () => {
  var a = loadlib("allfuncs")
  var lastob
  var isvisible = loadlib("isvisible")
  // var int
  // var last
  await a(
    ".blocklyToolboxDiv > div:nth-child(1)",
    ".blocklyToolboxDiv > div.scratchCategorySecondMenu.scratchCategoryMenu"
  ).waitforelem()
  await a(1000).wait()
  setup()
  ob()
  a("head").createelem("style", {
    innerHTML: `
  .blocklyToolboxDiv{
    width: 100% !important;
    }
    .scratchCategoryMenu{
      display: flex;
      flex-wrap: wrap;
      display:flex;
      justify-content:center;
      align-items:center;
      width:100%;
      }
      `,
  })
  setInterval(test, 400)
  var visible = false
  function test() {
    var elem
    if (
      !(elem = document.querySelector(
        ".blocklyToolboxDiv > div.scratchCategorySecondMenu.scratchCategoryMenu"
      ))
    )
      return (visible = false)
    if (!visible && elem && isvisible(elem)) setup()
    visible = isvisible(elem)
  }
  function setup() {
    if (lastob) {
      lastob.disconnect()
      lastob = null
    }
    document.querySelector(
      ".blocklyToolboxDiv"
    ).style.backgroundColor = "#00000033"
    document.querySelector(
      ".blocklyToolboxDiv > div:nth-child(1)"
    ).style.backgroundColor = "#00000033"
    document.querySelector(
      ".blocklyToolboxDiv > div.scratchCategorySecondMenu.scratchCategoryMenu"
    ).style.backgroundColor = "#00000033"
    var oldParent = document.querySelector(
      ".blocklyToolboxDiv > div.scratchCategorySecondMenu.scratchCategoryMenu"
    )
    var newParent = document.querySelector(
      ".blocklyToolboxDiv > div:nth-child(1)"
    )
    a(newParent).createelem("div", {
      backgroundColor: "transparent",
      minWidth: "100%",
      width: "100%",
    })
    while (oldParent.childNodes.length > 0) {
      newParent.appendChild(oldParent.childNodes[0])
    }
    // if (int) {
    //   if (Date.now() - last < 1000) return
    //   clearInterval(int)
    //   int = null
    // }
    // Trigger a window resize event
    window.dispatchEvent(new Event("resize"))

    setTimeout(() => {
      ob()
    }, 1200)
  }

  function ob() {
    if (lastob) {
      lastob.disconnect()
      lastob = null
    }
    if (
      !document.querySelector(".blocklyToolboxDiv > div:nth-child(1)")
    )
      return
    lastob = new MutationObserver((e) => {
      // console.warn(123312, lastob)
      if (lastob) {
        lastob.disconnect()
        lastob = null
      }
      if (
        !document.querySelector(
          ".blocklyToolboxDiv > div.scratchCategorySecondMenu.scratchCategoryMenu"
        )?.childElementCount
      )
        return
      // console.warn("started")
      setup()
      var int = setInterval(setup, 0)
      setTimeout(() => clearInterval(int), 1000)
    }).observe(
      document.querySelector(".blocklyToolboxDiv > div:nth-child(1)"),
      {
        subtree: 1,
        childList: 1,
      }
    )
    // console.error(lastob)
  }
})()
长期地址
遇到问题?请前往 GitHub 提 Issues。