From 4aa6c0fadf7427b3a510b4d9a7996887b0852f05 Mon Sep 17 00:00:00 2001
From: Obvious Alex C <76855369+David-Orangemoon@users.noreply.github.com>
Date: Sat, 2 Sep 2023 12:56:24 -0400
Subject: [PATCH] Add new tag blocks
---
extensions/obviousAlexC/TurboMD.js | 543 ++++++++++++++++-------------
1 file changed, 309 insertions(+), 234 deletions(-)
diff --git a/extensions/obviousAlexC/TurboMD.js b/extensions/obviousAlexC/TurboMD.js
index cd039ac9ae..c28d53fcbf 100644
--- a/extensions/obviousAlexC/TurboMD.js
+++ b/extensions/obviousAlexC/TurboMD.js
@@ -3,268 +3,343 @@
// Description: A XML, HTML, and SVG parser for turbowarp!
// By: ObviousAlexC
(function (Scratch) {
- "use strict";
- const parser = new DOMParser();
- let parseType = "text/html";
-
- const getParsedMD = (MD) => {
- if (parseType != "text/html") {
- if (MD.includes("?xml")) {
+ "use strict";
+ const parser = new DOMParser();
+ let parseType = "text/html";
+
+ const getParsedMD = (MD) => {
+ if (parseType != "text/html") {
+ if (MD.includes("?xml")) {
+ return [parser.parseFromString(MD, parseType), false];
+ }
+ return [
+ parser.parseFromString(
+ '' + MD + "",
+ parseType
+ ),
+ true,
+ ];
+ } else {
return [parser.parseFromString(MD, parseType), false];
}
- return [
- parser.parseFromString(
- '' + MD + "",
- parseType
- ),
- true,
- ];
- } else {
- return [parser.parseFromString(MD, parseType), false];
- }
- };
-
- class extension {
- getInfo() {
- return {
- blocks: [
- {
- opcode: "__NOUSEOPCODE",
- blockType: Scratch.BlockType.LABEL,
- text: "Tags",
- },
- {
- disableMonitor: true,
- opcode: "setTagFromHTML",
- blockType: Scratch.BlockType.REPORTER,
- text: "set tag [id] of type [tagName] to [value] from [MD]",
- arguments: {
- id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
- tagName: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "Color",
- },
- value: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "White",
- },
- MD: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "#FFFFFF",
- },
+ };
+
+ class extension {
+ getInfo() {
+ return {
+ blocks: [
+ {
+ blockType: Scratch.BlockType.LABEL,
+ text: "Tags",
},
- },
- {
- disableMonitor: true,
- opcode: "getTagFromHTML",
- blockType: Scratch.BlockType.REPORTER,
- text: "tag [id] of type [tagName] from [MD]",
- arguments: {
- id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
- tagName: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "Color",
- },
- MD: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "#FFFFFF",
+ {
+ disableMonitor: true,
+ opcode: "setTagFromHTML",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "set tag [id] of type [tagName] to [value] from [MD]",
+ arguments: {
+ id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ value: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "White",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "#FFFFFF",
+ },
},
},
- },
- {
- disableMonitor: true,
- opcode: "numberOfElementsOfTypeHTML",
- blockType: Scratch.BlockType.REPORTER,
- text: "# of elements of type [tagName] from [MD]",
- arguments: {
- tagName: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "Color",
- },
- MD: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "#FFFFFF",
+ {
+ disableMonitor: true,
+ opcode: "getTagFromHTML",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "tag [id] of type [tagName] from [MD]",
+ arguments: {
+ id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "#FFFFFF",
+ },
},
},
- },
- {
- opcode: "__NOUSEOPCODE",
- blockType: Scratch.BlockType.LABEL,
- text: "Attributes",
- },
- {
- disableMonitor: true,
- opcode: "setAttributeFromHTML",
- blockType: Scratch.BlockType.REPORTER,
- text: "set [attribute] of element [id] of type [tagName] to [setter] from [MD]",
- arguments: {
- attribute: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "name",
- },
- id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
- tagName: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "Color",
- },
- setter: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "green",
+ {
+ disableMonitor: true,
+ opcode: "numberOfElementsOfTypeHTML",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "# of elements of type [tagName] from [MD]",
+ arguments: {
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "#FFFFFF",
+ },
},
- MD: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: '#00FF00',
+ },
+ {
+ blockType: Scratch.BlockType.LABEL,
+ text: "Attributes",
+ },
+ {
+ disableMonitor: true,
+ opcode: "setAttributeFromHTML",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "set [attribute] of element [id] of type [tagName] to [setter] from [MD]",
+ arguments: {
+ attribute: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "name",
+ },
+ id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ setter: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "green",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: '#00FF00',
+ },
},
},
- },
- {
- disableMonitor: true,
- opcode: "getAttributeFromHTML",
- blockType: Scratch.BlockType.REPORTER,
- text: "[attribute] of element [id] of type [tagName] from [MD]",
- arguments: {
- attribute: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "name",
+ {
+ disableMonitor: true,
+ opcode: "removeAttributeFromHTML",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "remove [attribute] of element [id] of type [tagName] from [MD]",
+ arguments: {
+ attribute: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "name",
+ },
+ id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: '#00FF00',
+ },
+ },
},
- id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
- tagName: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: "Color",
+ {
+ disableMonitor: true,
+ opcode: "hasAttribute",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "[attribute] exists in element [id] of type [tagName] from [MD]",
+ arguments: {
+ attribute: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "name",
+ },
+ id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: '#00FF00',
+ },
+ },
+ },
+ {
+ disableMonitor: true,
+ opcode: "getAttributeFromHTML",
+ blockType: Scratch.BlockType.REPORTER,
+ text: "[attribute] of element [id] of type [tagName] from [MD]",
+ arguments: {
+ attribute: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "name",
+ },
+ id: { type: Scratch.ArgumentType.NUMBER, defaultValue: 1 },
+ tagName: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: "Color",
+ },
+ MD: {
+ type: Scratch.ArgumentType.STRING,
+ defaultValue: '#00FF00',
+ },
},
- MD: {
- type: Scratch.ArgumentType.STRING,
- defaultValue: '#00FF00',
+ },
+ {
+ blockType: Scratch.BlockType.LABEL,
+ text: "Settings",
+ },
+ {
+ disableMonitor: true,
+ opcode: "setParseMode",
+ blockType: Scratch.BlockType.COMMAND,
+ text: "Set parse mode to [mode]",
+ arguments: {
+ mode: { type: Scratch.ArgumentType.STRING, menu: "DocTypes" },
},
},
- },
- {
- opcode: "__NOUSEOPCODE",
- blockType: Scratch.BlockType.LABEL,
- text: "Settings",
- },
- {
- disableMonitor: true,
- opcode: "setParseMode",
- blockType: Scratch.BlockType.COMMAND,
- text: "Set parse mode to [mode]",
- arguments: {
- mode: { type: Scratch.ArgumentType.STRING, menu: "DocTypes" },
+ ],
+ menus: {
+ DocTypes: {
+ items: [
+ { text: "HTML", value: "text/html" },
+ { text: "XML", value: "text/xml" },
+ { text: "SVG", value: "image/svg+xml" },
+ ],
+ acceptReporters: false,
},
},
- ],
- menus: {
- DocTypes: {
- items: [
- { text: "HTML", value: "text/html" },
- { text: "XML", value: "text/xml" },
- { text: "SVG", value: "image/svg+xml" },
- ],
- acceptReporters: false,
- },
- },
- name: "Turbo XML",
- //For people who where already using the extension!
- id: "obviousAlexCTurbowarpMarkdown",
- menuIconURI:
- "",
- color1: "#59BC77",
- color2: "#47AB6A",
- color3: "#359258",
- };
- }
- setTagFromHTML({ id, tagName, value, MD }) {
- //Fix XML errors
- let retVALUE = getParsedMD(MD);
- let currentMarkDown = retVALUE[0];
-
- let element = retVALUE[1]
- ? currentMarkDown
- .getElementsByTagName("NOLOCK")[0]
- .getElementsByTagName(tagName)
- : currentMarkDown.getElementsByTagName(tagName);
- if (element) {
- element = element[id - 1];
+ name: "Turbo XML",
+ //For people who where already using the extension!
+ id: "obviousAlexCTurbowarpMarkdown",
+ menuIconURI:
+ "",
+ color1: "#59BC77",
+ color2: "#47AB6A",
+ color3: "#359258",
+ };
+ }
+ setTagFromHTML({ id, tagName, value, MD }) {
+ //Fix XML errors
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
if (element) {
- element.innerHTML = value;
- if (!currentMarkDown.body) {
- return "";
+ element = element[id - 1];
+ if (element) {
+ element.innerHTML = value;
+ if (!currentMarkDown.body) {
+ return "";
+ }
+ return currentMarkDown.body.innerHTML || "";
}
- return currentMarkDown.body.innerHTML || "";
}
+ return "";
}
- return "";
- }
- getTagFromHTML({ id, tagName, MD }) {
- let retVALUE = getParsedMD(MD);
- let currentMarkDown = retVALUE[0];
-
- let element = retVALUE[1]
- ? currentMarkDown
- .getElementsByTagName("NOLOCK")[0]
- .getElementsByTagName(tagName)
- : currentMarkDown.getElementsByTagName(tagName);
- if (element) {
- element = element[id - 1];
+ getTagFromHTML({ id, tagName, MD }) {
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
if (element) {
- return element.innerHTML || "";
+ element = element[id - 1];
+ if (element) {
+ return element.innerHTML || "";
+ }
}
+ return "";
}
- return "";
- }
- numberOfElementsOfTypeHTML({ tagName, MD }) {
- let retVALUE = getParsedMD(MD);
- let currentMarkDown = retVALUE[0];
-
- let element = retVALUE[1]
- ? currentMarkDown
- .getElementsByTagName("NOLOCK")[0]
- .getElementsByTagName(tagName)
- : currentMarkDown.getElementsByTagName(tagName);
- if (element) {
- return element.length;
+ numberOfElementsOfTypeHTML({ tagName, MD }) {
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
+ if (element) {
+ return element.length;
+ }
+ return 0;
}
- return 0;
- }
- setAttributeFromHTML({ attribute, id, tagName, setter, MD }) {
- let retVALUE = getParsedMD(MD);
- let currentMarkDown = retVALUE[0];
-
- let element = retVALUE[1]
- ? currentMarkDown
- .getElementsByTagName("NOLOCK")[0]
- .getElementsByTagName(tagName)
- : currentMarkDown.getElementsByTagName(tagName);
- if (element) {
- element = element[id - 1];
+ setAttributeFromHTML({ attribute, id, tagName, setter, MD }) {
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
if (element) {
- element.setAttribute(attribute, setter);
- return currentMarkDown.body.innerHTML;
+ element = element[id - 1];
+ if (element) {
+ element.setAttribute(attribute, setter);
+ return currentMarkDown.body.innerHTML;
+ }
}
+ return "";
}
- return "";
- }
- getAttributeFromHTML({ attribute, id, tagName, MD }) {
- let retVALUE = getParsedMD(MD);
- let currentMarkDown = retVALUE[0];
-
- let element = retVALUE[1]
- ? currentMarkDown
- .getElementsByTagName("NOLOCK")[0]
- .getElementsByTagName(tagName)
- : currentMarkDown.getElementsByTagName(tagName);
- if (element) {
- element = element[id - 1];
+ getAttributeFromHTML({ attribute, id, tagName, MD }) {
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
if (element) {
- return element.getAttribute(attribute) || "";
+ element = element[id - 1];
+ if (element) {
+ return element.getAttribute(attribute) || "";
+ }
}
+ return "";
}
- return "";
- }
- setParseMode({ mode }) {
- parseType = mode;
+ hasAttribute({ attribute, id, tagName, MD }) {
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
+ if (element) {
+ element = element[id - 1];
+ if (element) {
+ return element.hasAttribute(attribute) || false;
+ }
+ }
+ return false;
+ }
+ removeAttributeFromHTML({ attribute, id, tagName, MD }) {
+ let retVALUE = getParsedMD(MD);
+ let currentMarkDown = retVALUE[0];
+
+ let element = retVALUE[1]
+ ? currentMarkDown
+ .getElementsByTagName("NOLOCK")[0]
+ .getElementsByTagName(tagName)
+ : currentMarkDown.getElementsByTagName(tagName);
+ if (element) {
+ element = element[id - 1];
+ if (element) {
+ element.removeAttribute(attribute);
+ return currentMarkDown.body.innerHTML;
+ }
+ }
+ return "";
+ }
+ setParseMode({ mode }) {
+ parseType = mode;
+ }
+ runtime = Scratch.vm.runtime;
}
- runtime = Scratch.vm.runtime;
- }
- Scratch.extensions.register(new extension());
-})(Scratch);
+ Scratch.extensions.register(new extension());
+ })(Scratch);
+