// ==UserScript==
// @name scratch extended - change perms
// @version 0.1
// @description none
// @run-at context-menu
// @author You
// @match *://scratch.mit.edu/*
// @icon 
// @grant none
// @license GNU GPLv3
// @namespace https://greasyfork.org/users/1184528
// ==/UserScript==
(function() {
if (window?.__scratchextended) {
var ___scratchextended = ["all", ...Object.keys(__scratchextended).filter(
(e) => !["inputtype", "eventdata", "thread"].includes(e)
)]
var perms = JSON.parse(localStorage.getItem(`scratch:defaultperms`) || '[""]')
var div = createelem(
"div",
{
position: "absolute",
top: 0,
left: "0",
width: "min-content",
height: "0",
backgroundColor: "#444",
zIndex: 9999999,
},
document.body
)
createelem(
"p",
{ innerHTML: "default perms", color: "#0f0", backgroundColor: "#777" },
div
)
createelem(
"button",
{
innerHTML: "+",
onclick: () => {
var v = (___scratchextended).filter((k) => {
return ![...div.querySelectorAll("select")]
.map((e) => e.value || e)
.includes(k)
})
createoptions("", v, div)
},
},
div
)
createelem(
"button",
{
innerHTML: "save",
onclick: () => {
localStorage.setItem(
`scratch:defaultperms`,
JSON.stringify(
[...div.querySelectorAll("select")].map((e) => e.value)
)
)
localStorage.setItem(
`allowed:${
location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"
}`,
JSON.stringify(
[...div2.querySelectorAll("select")].map((e) => e.value)
)
)
localStorage.setItem(
`denied:${
location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"
}`,
JSON.stringify(
[...div3.querySelectorAll("select")].map((e) => e.value)
)
)
div.remove()
div2.remove()
div3.remove()
},
},
div
)
var v = (___scratchextended).filter((k) => {
return ![...perms, ...div.querySelectorAll("select")]
.map((e) => e.value || e)
.includes(k)
})
perms.forEach((e) => {
createoptions(e, v, div)
})
var perms2 = JSON.parse(
localStorage.getItem(
`allowed:${location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"}`
) || '[""]'
)
var div2 = createelem(
"div",
{
position: "absolute",
top: 0,
left: "150px",
width: "min-content",
height: "0",
backgroundColor: "#444",
zIndex: 9999999,
},
document.body
)
createelem(
"p",
{ innerHTML: "allowed perms", color: "#0f0", backgroundColor: "#777" },
div2
)
createelem(
"button",
{
innerHTML: "+",
onclick: () => {
var v = (___scratchextended).filter((k) => {
return ![...div2.querySelectorAll("select")]
.map((e) => e.value || e)
.includes(k)
})
v = v.filter((e) => !perms.includes(e))
createoptions("", v, div2)
},
},
div2
)
createelem(
"button",
{
innerHTML: "save",
onclick: () => {
localStorage.setItem(
`scratch:defaultperms`,
JSON.stringify(
[...div.querySelectorAll("select")].map((e) => e.value)
)
)
localStorage.setItem(
`allowed:${
location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"
}`,
JSON.stringify(
[...div2.querySelectorAll("select")].map((e) => e.value)
)
)
localStorage.setItem(
`denied:${
location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"
}`,
JSON.stringify(
[...div3.querySelectorAll("select")].map((e) => e.value)
)
)
div.remove()
div2.remove()
div3.remove()
},
},
div2
)
var v = (___scratchextended).filter((k) => {
return ![...perms2, ...div2.querySelectorAll("select")]
.map((e) => e.value || e)
.includes(k)
})
v = v.filter((e) => !perms.includes(e))
perms2.forEach((e) => {
createoptions(e, v, div2)
})
var perms3 = JSON.parse(
localStorage.getItem(
`denied:${location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"}`
) || '[""]'
)
var div3 = createelem(
"div",
{
position: "absolute",
top: 0,
left: "300px",
width: "min-content",
height: "0",
backgroundColor: "#444",
zIndex: 9999999,
},
document.body
)
createelem(
"p",
{ innerHTML: "denied perms", color: "#0f0", backgroundColor: "#777" },
div3
)
createelem(
"button",
{
innerHTML: "+",
onclick: () => {
var v = (___scratchextended).filter((k) => {
return ![...div3.querySelectorAll("select")]
.map((e) => e.value || e)
.includes(k)
})
v = v.filter((e) => !perms.includes(e))
createoptions("", v, div3)
},
},
div3
)
createelem(
"button",
{
innerHTML: "save",
onclick: () => {
localStorage.setItem(
`scratch:defaultperms`,
JSON.stringify(
[...div.querySelectorAll("select")].map((e) => e.value)
)
)
localStorage.setItem(
`allowed:${
location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"
}`,
JSON.stringify(
[...div2.querySelectorAll("select")].map((e) => e.value)
)
)
localStorage.setItem(
`denied:${
location.href.match(/(?<=\/)[0-9]+(?=\/)/)?.[0] || "local"
}`,
JSON.stringify(
[...div3.querySelectorAll("select")].map((e) => e.value)
)
)
div.remove()
div2.remove()
div3.remove()
},
},
div3
)
var v = (___scratchextended).filter((k) => {
return ![...perms3, ...div3.querySelectorAll("select")]
.map((e) => e.value || e)
.includes(k)
})
v = v.filter((e) => !perms.includes(e))
perms3.forEach((e) => {
createoptions(e, v, div3)
})
function createoptions(perm, options, div) {
options = options.filter((e) => e !== perm)
var s = createelem(
"select",
{
onchange: (e) => {
if (e.target.value == "remove") {
e.target.remove()
}
},
},
div
)
;["remove", perm, ...options].forEach((e) => {
if (e !== "requestperms")
createelem("option", { value: e, innerHTML: e }, s)
})
s.value = perm
}
function createelem(elem, data, parent) {
elem = document.createElement(elem)
if (data.style)
data.style.split(" ").forEach((e) => {
elem.classList.add(e)
})
Object.assign(elem.style, data)
Object.assign(elem, data)
if (typeof parent == "string") parent = zzz.qs(parent)
parent?.appendChild(elem)
return elem
}
} else {
alert('you must have scratch extended running before this can be run')
}
})();