diff --git a/Gallery Files/Contributors.json b/Gallery Files/Contributors.json index cf88df41..16277086 100644 --- a/Gallery Files/Contributors.json +++ b/Gallery Files/Contributors.json @@ -74,5 +74,9 @@ { "display": "ObscuraPH", "username": "PH8NT0MH4WK", "url": "https://avatars.githubusercontent.com/u/113964833?v=4" + }, + { + "display": "cs3203402", "username": "cs3203402", + "url": "https://avatars.githubusercontent.com/u/223149891?v=4" } ] diff --git a/Gallery Files/Extension-Keys.json b/Gallery Files/Extension-Keys.json index a8d24e18..c0c21544 100644 --- a/Gallery Files/Extension-Keys.json +++ b/Gallery Files/Extension-Keys.json @@ -593,6 +593,14 @@ "tags": ["all", "utilities"], "date": "Released: 10/24/2025" }, + "Gemini": { + "desc": "Send requests to Gemini API.", + "creator": "cs3203402", + "url": "extension-code/Gemini-API.js", + "banner": "extension-thumb/Gemini.svg", + "tags": ["all", "fetching"], + "date": "Released: 12/29/2025" + }, "Example": { "desc": "", "creator": "SharkPool", diff --git a/extension-code/Gemini-API.js b/extension-code/Gemini-API.js new file mode 100644 index 00000000..c122b1cf --- /dev/null +++ b/extension-code/Gemini-API.js @@ -0,0 +1,149 @@ +// Name: Gemini API +// ID: smolderdevGeminiAPI +// Description: Gemini API Requests with Customization +// By: cs3203402 +// License: MIT + +// Version V.1.0.0 + +(async function(Scratch) { + "use strict"; + + const menuIconURI = +""; + + // typically extensions should work offline, but this is a online AI extension, + // so all offline rules break for this... + const { GoogleGenAI } = await import("https://cdn.jsdelivr.net/npm/@google/genai@1.33.0/+esm") + + const displayModels = [ + "Gemini 2.5 - Flash Lite", "Gemini 2.5 - Flash", "Gemini 2.5 - Pro", + "Gemini 3 - Flash (Preview)", "Gemini 3 - Pro (Preview)", "Gemini 3 - Deep Thinking" + ]; + const actualModels = [ + "gemini-2.5-flash-lite", "gemini-2.5-flash", "gemini-2.5-pro", + "gemini-3-flash-preview", "gemini-3-pro-preview", "gemini-3-deep-think" + ]; + + let ai = new GoogleGenAI({ apiKey: "" }); + let instruction = ""; + let key = "No API key has been set."; + let modelChoice = "gemini-2.5-flash"; + + class smolderdevGeminiAPI { + getInfo() { + return { + id: "smolderdevGeminiAPI", + name: Scratch.translate("Gemini API"), + color1: "#0086c9", + menuIconURI, + blockIconURI: menuIconURI, + blocks: [ + { + opcode: "generate", + blockType: Scratch.BlockType.REPORTER, + text: Scratch.translate( + "generate with prompt [contents] and creativity (0-2) [temp]" + ), + arguments: { + contents: { + type: Scratch.ArgumentType.STRING, + defaultValue: "Tell me about Gemini.", + }, + temp: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 1, + }, + }, + }, + { + opcode: "getKey", + blockType: Scratch.BlockType.REPORTER, + text: Scratch.translate("current API key"), + }, + { + opcode: "getModel", + blockType: Scratch.BlockType.REPORTER, + text: Scratch.translate("selected model"), + }, + { + opcode: "setKey", + blockType: Scratch.BlockType.COMMAND, + text: Scratch.translate("set API key to [key]"), + arguments: { + key: { + type: Scratch.ArgumentType.STRING, + defaultValue: "", + }, + }, + }, + { + opcode: "setInstruction", + blockType: Scratch.BlockType.COMMAND, + text: Scratch.translate("set personality to [personality]"), + arguments: { + personality: { + type: Scratch.ArgumentType.STRING, + defaultValue: "", + }, + }, + }, + { + opcode: "setModel", + blockType: Scratch.BlockType.COMMAND, + text: Scratch.translate("use model [model]"), + arguments: { + model: { + type: Scratch.ArgumentType.STRING, + menu: "models", + }, + }, + }, + ], + menus: { + models: displayModels + }, + }; + } + + async generate(args) { + const response = await ai.models.generateContent({ + model: getActualModel(modelChoice), + contents: Scratch.Cast.toString(args.contents), + config: { + systemInstruction: instruction, + temperature: Math.max(0, Math.min(2, Scratch.Cast.toNumber(args.temp))), + }, + }); + return response.text; + } + + setKey(args) { + key = Scratch.Cast.toString(args.key); + ai = new GoogleGenAI({ + apiKey: key + }); + } + + setInstruction(args) { + instruction = Scratch.cast.toString(args.personality); + } + + setModel(args) { + modelChoice = Scratch.Cast.toString(args.model); + } + + getKey() { + return key; + } + + getModel() { + return modelChoice; + } + + getActualModel(display) { + return actualModels[displayModels.indexOf(display)]; + } + } + Scratch.extensions.register(new smolderdevGeminiAPI()); +})(Scratch); diff --git a/extension-thumbs/Gemini.svg b/extension-thumbs/Gemini.svg new file mode 100644 index 00000000..68c871a8 --- /dev/null +++ b/extension-thumbs/Gemini.svg @@ -0,0 +1 @@ +