<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <!-- saved from url=(0055)https://floooh.github.io/sokol-html5/triangle-sapp.html --> <html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>AI RPG</title> <style type="text/css"> body { margin: 0; background-color: black; } .game-title { pointer-events: none; position: absolute; bottom: 10px; margin-top: 0px; padding-left: 10px; color: white; text-decoration: none; z-index: 1; text-align: left; font-family: "Arial Black", Gadget, sans-serif; font-size: 30px; } .game-menu-item { pointer-events: auto; font-size: 18px; padding-left: 10px; font-family: Arial, Helvetica, sans-serif; } .game-menu-link { text-decoration: none; color: white; } .game { position: absolute; top: 0px; left: 0px; margin: 0px; border: 0; width: 100%; height: 100%; overflow: hidden; display: block; image-rendering: optimizeSpeed; image-rendering: -moz-crisp-edges; image-rendering: -o-crisp-edges; image-rendering: -webkit-optimize-contrast; image-rendering: optimize-contrast; image-rendering: crisp-edges; image-rendering: pixelated; -ms-interpolation-mode: nearest-neighbor; } .inputdiv { position: absolute; top: 0px; left: 0px; margin: 0px; border: 0; width: 100%; height: 100%; overflow: hidden; display: none; /* set to flex by javascript */ justify-content: center; align-items: center; z-index: 10; background: #00000090; } #inputtext { position: absolute; top: 0; left: 0; background: none; width: 90%; height: 50%; margin-left: 5%; margin-right: 5%; border-top-style: hidden; border-right-style: hidden; border-left-style: hidden; border-bottom-style: hidden; transform: translateY(100%); text-align: center; font-size: 2em; font-family: Arial; color: white; } #inputtext:focus { outline: none; } #inputbutton { bottom: 0; margin-bottom: 10%; position: absolute; font-family: Arial; font-size: 3em; } </style> <link id="sokol-app-favicon" rel="shortcut icon" href=""></head> <body style="background:black"> <div id="inputdiv" class="inputdiv"> <textarea onkeyup='on_textarea_key(event);' id="inputtext"> </textarea> <button id="inputbutton" onclick="end_dialog()"> Submit </button> </div> <canvas class="game" id="canvas" oncontextmenu="event.preventDefault()" width="1504" height="864"></canvas> <script type="text/javascript"> var Module = { preRun: [], postRun: [], print: (function() { return function(text) { text = Array.prototype.slice.call(arguments).join(' '); console.log(text); }; })(), printErr: function(text) { text = Array.prototype.slice.call(arguments).join(' '); console.error(text); }, canvas: (function() { var canvas = document.getElementById('canvas'); canvas.addEventListener("webglcontextlost", function(e) { alert('FIXME: WebGL context lost, please reload the page'); e.preventDefault(); }, false); return canvas; })(), setStatus: function(text) { }, monitorRunDependencies: function(left) { }, }; window.onerror = function(event) { console.log("onerror: " + event.message); }; </script> <script type="text/javascript"> function start_dialog() { document.getElementById("inputtext").value = ""; setTimeout(function(){document.getElementById("inputtext").focus();},200); // for some reason focus doesn't work immediately here document.getElementById("inputdiv").style.display = "flex"; } function end_dialog() { document.getElementById("inputdiv").style.display = "none"; Module.ccall('end_text_input', 'void', ['string'], [document.getElementById("inputtext").value]); } function on_textarea_key(event) { let final_textarea_string = ""; let cur_textarea_string = document.getElementById("inputtext").value; let should_end = false; for(let i = 0; i < Math.min(cur_textarea_string.length, 250); i++) { let cur = cur_textarea_string[i]; if(cur === "\n") { should_end = true; continue; } if(cur.charCodeAt(0) >= 255) continue; // non ascii gtfo final_textarea_string += cur_textarea_string[i]; } document.getElementById("inputtext").value = final_textarea_string; if(should_end) end_dialog(); if(event.key === "Enter") end_dialog(); if(event.key === "Escape") { document.getElementById("inputtext").value = ""; end_dialog(); } } const max_retries = 5; let cur_id = 1; // zero is not a valid id, the zero value means no async request currently active let generation_requests = []; // array of dictionaries with structure: /* { id: number, request: XMLHTTPRequest, request_info: { url: string, body: string } retries_remaining: number, // on failure, retries over and over until out of retries } */ function resend_request(r) { r.request.open("POST", r.request_info.url, true); r.request.send(r.request_info.body); } // Returns an integer, a "handle" into the generation request. Takes in the string prompt, and api URL // the api url must start with `http://` or https. function make_generation_request(p, api) { cur_id += 1; let to_push = { "id": cur_id, "request": new XMLHttpRequest(), "retries_remaining": 5, "request_info": {"url": api, "body": p} } console.log("Making generation request with id " + to_push.id); generation_requests.push(to_push) resend_request(to_push) return cur_id; } // returns 0 if not done yet, 1 if succeeded, 2 if failed after too many retries (i.e server down, or no internet) // -1 if it doesn't exist function get_generation_request_status(id) { for(let i = 0; i < generation_requests.length; i++) { if(generation_requests[i].id == id) { let http_status = generation_requests[i].request.status; if(http_status == 200) { return 1; } else if(http_status == 0) { // not done yet return 0; } else { // errored if(generation_requests[i].retries_remaining > 0) { generation_requests[i].retries_remaining -= 1; resend_request(generation_requests[i]); return 0; } else { return 2; // too many retries, failed } } } } return -1; } function done_with_generation_request(id) { console.log("Removing request with id " + id); let new_generation_requests = []; for(let i = 0; i < generation_requests.length; i++) { if(generation_requests[i].id == id) { } else { new_generation_requests.push(generation_requests[i]) } } generation_requests = new_generation_requests; } // doesn't fill string if not done yet, or the id doesn't exist function get_generation_request_content(id) { let to_return = ""; for(let i = 0; i < generation_requests.length; i++) { if(generation_requests[i].id == id) { to_return = generation_requests[i].request.responseText; break; } } return to_return;; } </script> {{{ SCRIPT }}} </body></html>