diff --git a/extensions/community/FileDrop.json b/extensions/community/FileDrop.json new file mode 100644 index 000000000..b9aa45c2d --- /dev/null +++ b/extensions/community/FileDrop.json @@ -0,0 +1,195 @@ +{ + "author": "", + "category": "User interface", + "extensionNamespace": "", + "fullName": "File drop", + "helpPath": "", + "iconUrl": "", + "name": "FileDrop", + "previewIconUrl": "https://asset-resources.gdevelop.io/public-resources/Icons/874a229613921627ff0a1d3b943a84eb9795cbde9f5b14e576c4eb29822c9d24_file-eye-outline.svg", + "shortDescription": "Adds the ability to read the content, name, path, and size of a file dropped into the game's window.", + "version": "1.0.0", + "description": [ + "Some examples why you might find this extension helpful:", + "", + "- Let players load text into your game with just dragging a TXT file into the window", + "", + "- Let players load up a level from a JSON file", + "", + "- If you have a multiplayer game, or any game where players can create their own profile picture or upload anything, load the image from a file that contains the base64 image. You can use other extensions, or create your own way to handle base64", + "", + "- You can use basically any format for the file(s) your game will support, as long as it's readable. For example, if you have a simple text that is readable from a \"TXT\" file (e.g.: \"text123.txt\"), but you want to use your own file format, let's say \"MYGAME\" (e.g.: text123.mygame), it will work if the content remains string. Same for everything else, like a level data (level123.json -> level123.mygame) as long as the content can be converted from JSON to variable(s)", + "", + "With this said, it's completely up to your imagination how you will use this extension." + ], + "tags": [], + "authorIds": [], + "dependencies": [], + "globalVariables": [], + "sceneVariables": [], + "eventsFunctions": [ + { + "description": "Listens if a file is being dropped into the window and returns its path into the scene variable \"_fileDropPath\".", + "fullName": "Listen and return path", + "functionType": "Action", + "name": "ListenAndReturnPath", + "sentence": "Listen for a file drop and return its path", + "events": [ + { + "type": "BuiltinCommonInstructions::JsCode", + "inlineCode": [ + "window.addEventListener('dragover', (event) => {", + " event.preventDefault(); ", + "});", + "", + "window.addEventListener('drop', (event) => {", + " event.preventDefault();", + "", + " const files = event.dataTransfer.files;", + " if (files.length > 0) {", + " const file = files[0];", + "", + " // Attempt to get the full path (might be restricted by browser security)", + " const filePath = file.path || file.name; // Fallback to file name if path is not available", + "", + " console.log(\"Dropped file path:\", filePath);", + "", + " // Store the file path in the scene variable \"_fileDropPath\"", + " runtimeScene.getVariables().get(\"_fileDropPath\").setString(filePath); ", + " }", + "});" + ], + "parameterObjects": "", + "useStrict": true, + "eventsSheetExpanded": false + } + ], + "parameters": [], + "objectGroups": [] + }, + { + "description": "Listens if a file is being dropped into the window and returns its name into the scene variable \"_fileDropName\".", + "fullName": "Listen and return name", + "functionType": "Action", + "name": "ListenAndReturnName", + "sentence": "Listen for a file drop and return its name", + "events": [ + { + "type": "BuiltinCommonInstructions::JsCode", + "inlineCode": [ + "window.addEventListener('dragover', (event) => {", + " event.preventDefault(); ", + "});", + "", + "window.addEventListener('drop', (event) => {", + " event.preventDefault();", + "", + " const files = event.dataTransfer.files;", + " if (files.length > 0) {", + " const file = files[0];", + "", + " const fileName = file.name; // Get only the file name", + "", + " console.log(\"Dropped file name:\", fileName);", + "", + " // Store the file name in the scene variable \"_fileDropName\"", + " runtimeScene.getVariables().get(\"_fileDropName\").setString(fileName); ", + " }", + "});" + ], + "parameterObjects": "", + "useStrict": true, + "eventsSheetExpanded": false + } + ], + "parameters": [], + "objectGroups": [] + }, + { + "description": "Listens if a file is being dropped into the window and returns its size in bytes into the scene variable \"_fileDropSize\".", + "fullName": "Listen and return size", + "functionType": "Action", + "name": "ListenAndReturnSize", + "sentence": "Listen for a file drop and return its size", + "events": [ + { + "type": "BuiltinCommonInstructions::JsCode", + "inlineCode": [ + "window.addEventListener('dragover', (event) => {", + " event.preventDefault(); ", + "});", + "", + "window.addEventListener('drop', (event) => {", + " event.preventDefault();", + "", + " const files = event.dataTransfer.files;", + " if (files.length > 0) {", + " const file = files[0];", + "", + " // Get the file size in bytes", + " const fileSize = file.size;", + "", + " console.log(\"File size (bytes):\", fileSize);", + "", + " // Store the file size in the scene variable \"_fileDropSize\"", + " runtimeScene.getVariables().get(\"_fileDropSize\").setNumber(fileSize); ", + " }", + "});" + ], + "parameterObjects": "", + "useStrict": true, + "eventsSheetExpanded": false + } + ], + "parameters": [], + "objectGroups": [] + }, + { + "description": "Listens if a file is being dropped into the window and returns its content as text into the scene variable \"_fileDropContent\".", + "fullName": "Listen and return content", + "functionType": "Action", + "name": "ListenAndReturnContent", + "sentence": "Listen for a file drop and return its content", + "events": [ + { + "type": "BuiltinCommonInstructions::JsCode", + "inlineCode": [ + "window.addEventListener('dragover', (event) => {", + " event.preventDefault(); ", + "});", + "", + "window.addEventListener('drop', (event) => {", + " event.preventDefault();", + "", + " const files = event.dataTransfer.files;", + " if (files.length > 0) {", + " const file = files[0];", + "", + " const reader = new FileReader();", + "", + " reader.onload = (e) => {", + " const fileContent = e.target.result;", + "", + " console.log(\"File content:\", fileContent);", + "", + " // Store the file content in the scene variable \"_fileDropContent\"", + " runtimeScene.getVariables().get(\"_fileDropContent\").setString(fileContent); ", + " };", + "", + " // Read the file as text", + " reader.readAsText(file);", + " }", + "});" + ], + "parameterObjects": "", + "useStrict": true, + "eventsSheetExpanded": false + } + ], + "parameters": [], + "objectGroups": [] + } + ], + "eventsBasedBehaviors": [], + "eventsBasedObjects": [] +} \ No newline at end of file