NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name FC Enhance--Jelly's Dev Version // @namespace catastrophe.box.eggsal.com // @description Adds functionality to FC | Creators: Marjo, uJellyBrah, Zhyrek, and ID36. Links to website by ID36, links to fc resource by sk89q, inspiration from FC++ by sk89q. // @include *fantasticcontraption.com* // @exclude *archive.org* // @require http://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js // @version 3.2 // @updateURL https://openuserjs.org/meta/Pravet/FC_Enhance--Jellys_Dev_Version.meta.js // @grant GM_xmlhttpRequest // @grant GM_setValue // @grant GM_getValue // @grant unsafeWindow // ==/UserScript== //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////SCREEN SCALE///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var scale = screen.width/1920; // Used to scale elements by brute force for different resolutions //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////SWF LOCATION///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var locationBox = document.getElementsByClassName('left')[0].getBoundingClientRect(); // Get the pixel location of the centered div...used to position other elements relative to its location //First we must detect if the page is simply the advertisement page and break here if (unsafeWindow.location.href.search(/fantasticcontraption.com\/original/) < 0 && unsafeWindow.location.href.search(/fantasticcontraption.com\/\?/) < 0) { throw new Error(); //First try to stop script } try { if (window.constructor != unsafeWindow.constructor) window = unsafeWindow; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////MAKE ID////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function makeid(len) //Create random sequence of characters to use for username, email, password { var text = ""; var possible = "abcdefghijklmnopqrstuvwxyz"; for( var i=0; i < len; i++ ) text += possible.charAt(Math.floor(Math.random() * possible.length)); return text; } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////GET COOKIES////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getCookie(cname) { //Get a cookie by its name var name = cname + "="; var ca = document.cookie.split(';'); for(var i=0; i<ca.length; i++) { var c = ca[i]; while (c.charAt(0)==' ') c = c.substring(1); if (c.indexOf(name) == 0) return c.substring(name.length,c.length); } return false; } //We must set a cookie to give each user a different ID. We must create a new account and store the id. if (!getCookie("userid")) { $.ajax({ type: "POST", dataType: "xml", url: "newUser.php", data: { userName: Math.floor(Math.random() * 100000000000000), password: Math.floor(Math.random() * 100000000000000), email: makeid(10) + "@gmail.com" }, success: function(data){ var newId; try { newId = data.getElementsByTagName('userId')[0].innerHTML; } catch(err) { unsafeWindow.location.reload(); } if (newId) { //If the acount was created successfully document.cookie = "userid=" + newId + "; expires=01 Jan 2999 00:00:00 UTC; path=/"; } else { unsafeWindow.location.reload(); } } }); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////GET FLASH//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getFlash() { movieName = "contraption"; if (unsafeWindow.document[movieName]) { return unsafeWindow.document[movieName]; } if (navigator.appName.indexOf("Microsoft Internet")==-1) { if (document.embeds && document.embeds[movieName]) return document.embeds[movieName]; } else { return document.getElementById(movieName); } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////VARIABLES//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var inFullScreen = false; var pageLocked = false; var defaultOnBeforeUnload = window.onbeforeunload; var messageTimeout; var contraption = getFlash(); var currentPageNumber = 0; var centered = document.getElementsByClassName("centered")[currentPageNumber]; //This is where we shall add the stuff for the main screen centered.setAttribute("data-pagedescription", "Fantastic Contraption"); var randLevDisplayPlaceholder = ""; var lockPic = ""; var unlockPic = ""; var refreshPic = ""; var chatButtonPic = ""; var chatButtonHoverPic = ""; var rightArrowPic = ""; var leftArrowPic = ""; var settingsPic = ""; var settingsBtn = ""; //Zones var bottomZone; var rightZone; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //-------- BEGIN THE LONG FUNCTION THAT ALLOWS ME TO HAVE OTHER FUNCTIONS IN IT! --------///////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //Disable if no cookies if (!navigator.cookieEnabled) { alert("Sorry, you need cookies enabled to run FC Enhance.\nIf you think this is a mistake, please contact marjo."); return "Browser does not support cookies."; } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////ADD ZONES//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addZones() { //Bottom zone bottomZone = document.createElement("div"); with (bottomZone) { style.position = "absolute"; style.bottom = "1px"; style.width = "99%"; style.textAlign = "center"; id = "bottomZone"; } //document.body.appendChild(bottomZone); rightZone = document.createElement("div"); with (rightZone) { style.position = "absolute"; style.bottom = "0"; } //document.body.appendChild(rightZone); } addZones(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////RANDOM LEVEL HUB///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addRandLevelStuff() { var randLevelHub = document.createElement('div'); randLevelHub.style.position = "absolute"; randLevelHub.style.top = 48*scale+"px"; randLevelHub.style.right = 20*scale+"px"; randLevelHub.style.width = 300*scale+"px"; randLevelHub.style.borderStyle = "solid"; randLevelHub.style.borderRadius = 25*scale+"px"; randLevelHub.style.borderColor = "blue"; randLevelHub.id = "randLevelHub"; randLevelHub.style.fontSize = 1*scale+"em"; randLevelHub.innerHTML = "<center><div id = 'innerHub'><legend>ID36 Random Unsolved Level Hub</legend></div><center>"; centered.appendChild(randLevelHub); var innerHub = document.getElementById('innerHub'); var display = document.createElement('img'); display.src = randLevDisplayPlaceholder; display.style.height = 132*scale+"px"; display.style.border = "none"; display.id = "randLevelDisplay"; innerHub.appendChild(display); innerHub.innerHTML += "<br />"; var genButton = document.createElement('input'); genButton.type = "button"; genButton.value = "New level"; genButton.style.padding = 3*scale+"px"; genButton.id = "randLevelButton"; genButton.addEventListener('click', function(event) { getRandLevel(); }); innerHub.appendChild(genButton); } addRandLevelStuff(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////GET RANDOM LEVEL///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getRandLevel() { document.getElementById('randLevelDisplay').removeEventListener('click', this.redirectToRandLevel); document.getElementById('randLevelButton').disabled = "true"; document.getElementById('randLevelButton').value = "Loading..."; document.getElementById('randLevelDisplay').src = randLevDisplayPlaceholder; document.getElementById('randLevelDisplay').style.border = "none"; document.getElementById('randLevelDisplay').style.cursor = "auto"; document.getElementById('randLevelDisplay').style.height = 132*scale+"px"; GM_xmlhttpRequest({ method: "GET", dataType: "text", url: "http://id36.ueuo.com/lvl-us.php", onload: function(response) { setRandLevel(response); } }); function setRandLevel(response) { srcXML = response.responseText; //Find image data URL var dataURL = srcXML.match(/src='data:image.*?[\w=]'/g)[0]; //Match starting with the data: and ending in either an equals sign or a space. Nongreedy star. dataURL = dataURL.substring(5, dataURL.length-1); //Now find link var href = srcXML.match(/href='http:\/\/FantasticContraption.com\/\?levelId=\d*/g)[0]; href = href.substring(6); var unsLevId = href.split("=")[1]; document.getElementById('randLevelDisplay').src = dataURL; this.redirectToRandLevel = function(event) { //unsafeWindow.location.href = href; loadLvl(unsLevId); }; document.getElementById('randLevelDisplay').addEventListener('click', this.redirectToRandLevel); document.getElementById('randLevelDisplay').style.border = "1px solid black"; document.getElementById('randLevelDisplay').style.height = 130*scale+"px"; document.getElementById('randLevelDisplay').style.cursor = "pointer"; document.getElementById('randLevelButton').disabled = false; document.getElementById('randLevelButton').value = "New level"; } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////CHAT HUB///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addChatHub(changingNick) { //We will in this function add the default username box etc. This is the logic thatcontrols the chat //Add the base DIV var chatHub = document.createElement('div'); //Create the surrounding div chatHub.style.position = "absolute"; //Positioning chatHub.style.top = 258*scale+"px"; //etc. chatHub.style.right = 27*scale+"px"; //etc. chatHub.style.width = 350*scale+"px"; chatHub.style.borderStyle = "none"; chatHub.style.borderRadius = 25*scale+"px"; chatHub.style.borderColor = "blue"; chatHub.id = "chatHub"; //Set an id document.body.appendChild(chatHub); //Add the div to the document. It will not dissapear when other pages are requested var startChatButton = document.createElement("img"); //Create the button to load the chat startChatButton.style.marginTop = 30*scale+"px"; //Offset it a little bit startChatButton.id = "startChatButton"; startChatButton.style.width = 160*scale+"px"; startChatButton.style.height = 56*scale+"px"; startChatButton.src = chatButtonPic; //Set the image. This variable was defined in the variables section //We want to add a hover image, to make it clear you can click it. startChatButton.addEventListener('mouseover', function() { //When the mouse hovers on the button this.src = chatButtonHoverPic; }); startChatButton.addEventListener('mouseout', function() { //When the mouse leaves the button this.src = chatButtonPic; }); startChatButton.addEventListener('click', function() { //On click var chatLogin = document.createElement("div"); chatLogin.id = "chatLogin"; chatLogin.style.borderStyle = "solid"; chatLogin.style.borderRadius = 25*scale+"px"; chatLogin.style.borderColor = "blue"; document.getElementById("chatHub").appendChild(chatLogin); var chatUser = document.createElement("h5"); chatUser.innerHTML = "Please Enter Your FC Username:"; document.getElementById("chatLogin").appendChild(chatUser); var userInput = document.createElement("input"); userInput.id = "userInput"; document.getElementById("chatLogin").appendChild(userInput); var chatPass = document.createElement("h5"); chatPass.innerHTML = "Please Enter Your Password:"; document.getElementById("chatLogin").appendChild(chatPass); var userPass = document.createElement("input"); userPass.id = "userPass"; userPass.type = "password"; document.getElementById("chatLogin").appendChild(userPass); var newLine = document.createElement("br"); document.getElementById("chatLogin").appendChild(newLine); var startChatBtn = document.createElement("input"); startChatBtn.id = "startChatBtn"; startChatBtn.type = "button"; startChatBtn.value = "Start Chatting!"; startChatBtn.addEventListener('click', function(){ var user = document.getElementById("userInput").value; var pass = document.getElementById("userPass").value; $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/logIn.php", data: { userName: user, password: pass }, success: function(data) { console.log(data.getElementsByTagName("userName")[0]); if(data.getElementsByTagName("userName")[0]){ var id = data.getElementsByTagName("userName")[0].innerHTML; } //console.log(id); if(id){ addChat(id, chatHub); document.getElementById("chatHub").removeChild(chatLogin); }else{ alert("Incorrect Login!"); } } }); }); document.getElementById("chatLogin").appendChild(startChatBtn); //addChat(getCookie('chatusername'), chatHub); //Add the chat, passing in the username value, which is simply the value of the cookie, and chatHub as the element to put the chat inside document.getElementById("chatHub").removeChild(this); }); //Add the button to the hub document.getElementById("chatHub").appendChild(startChatButton); } addChatHub(); function addChat(userName, area) { //When this function is called, it will add the iframe and set the src to include the username var chatHub = area; //Take note of the area to put the chat in var chatFrame = document.createElement('iframe'); //Create the iframe chatFrame.src = "https://widget00.mibbit.com/?server=irc.theairlock.net&channel=%23fc&noServerTab=false&autoConnect=true&settings=e1d7b68ebbe5f006878f38537f7375c5&nick=" + userName; //Set the source //chatFrame.src = "https://kiwiirc.com/client/frozen.coldfront.net/?nick="+userName+"?#fc"; //Set the source chatHub.appendChild(chatFrame); //Add in the iframe chatFrame.id = "chat"; //Set an id for the iframe window.addEventListener("resize", function() { //This is all just to make sure the iframe resizes based on the window dimensions var vw = unsafeWindow.innerWidth / 100; var vh = unsafeWindow.innerHeight / 100; var heightPercentage = 60; //Change this value to tune var chatWidth = 350*scale+"px"; var chatHeight = (heightPercentage * vh) + "px"; chatHub.style.width = chatWidth; chatHub.style.height = chatHeight; chatFrame.style.borderStyle = "solid"; chatFrame.style.borderRadius = 25*scale+"px"; chatFrame.style.borderColor = "#2550FF"; chatFrame.width = chatWidth; chatFrame.height = chatHeight; }); window.dispatchEvent(new Event('resize')); //Set initial sizes based on window size } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FULLSCREEN TOGGLE//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addFullScreenButton() { plusIcon = ''; minusIcon = ''; fullScreenToggle = document.createElement("img"); with (fullScreenToggle) { setAttribute("src", plusIcon); id = "fullScreenButton"; style.height = 32*scale+"px"; title = "Toggle Fullscreen"; style.width = 32*scale+"px"; style.position = "absolute"; style.top = 4*scale+"px"; style.left = 4*scale+"px"; style.cursor = "pointer"; } //The toggle fullScreenToggle.addEventListener('click', function(event){ if (!inFullScreen) { var game = contraption; with (game) { style.position = "absolute"; style.top = "45px"; style.left = "calc(50% - "+540*scale+"px)"; style.border = 10*scale+"px solid #2550FF"; style.borderRadius = 25*scale+"px"; height = 771.42857*scale+"px"; width = 1080*scale+"px"; } var freeLevel = document.getElementsByClassName("right")[0]; //Free level of the month with (freeLevel) { style.display = "none"; } var border = document.getElementsByClassName("border")[0]; //Blue border with (border) { style.padding = "0px"; style.backgroundImage = "url('')"; } var titlePic = document.getElementsByTagName("h1")[0]; //FC Logo with (titlePic) { style.display = "none"; } var topText = document.getElementsByTagName("h2")[0]; //Fun online physic... etc. with (topText) { style.display = "none"; } with (fullScreenToggle) { setAttribute("src", minusIcon); } inFullScreen = true; document.cookie = "fullscreen=yes; expires=01 Jan 2999 00:00:00 UTC; path=/"; } else { with (fullScreenToggle) { setAttribute("src", plusIcon); } var game = contraption; var border = document.getElementById("maincontent"); with (game) { style.position = "relative"; style.top = "initial"; style.left = "initial"; style.border = ""; style.borderRadius = ""; height = "500px"; width = "700px"; } var freeLevel = document.getElementsByClassName("right")[0]; //Free level of the month with (freeLevel) { style.display = "initial"; } var border = document.getElementsByClassName("border")[0]; //Blue border with (border) { style.padding = "20px 0px 0px 20px"; style.backgroundImage = "url('http://fantasticcontraption.com/images/fantastic_contraption_border.png')"; //style.position = "relative"; //style.top = "initial"; //style.left = "initial"; } var titlePic = document.getElementsByTagName("h1")[0]; //FC Logo with (titlePic) { style.display = "initial"; } var topText = document.getElementsByTagName("h2")[0]; //Fun online physic... etc. with (topText) { style.display = "block"; } inFullScreen = false; document.cookie = "fullscreen=no; expires=01 Jan 2999 00:00:00 UTC; path=/"; } }); centered.appendChild(fullScreenToggle); if (getCookie("fullscreen") == "yes") { fullScreenToggle.click(); } } addFullScreenButton(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////ADD LOCK BUTTON////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addLockButton() { var lockToggle = document.createElement("img"); with (lockToggle) { src = unlockPic; id = "lockButton"; style.height = 32*scale+"px"; title = "Lock Page"; style.width = 32*scale+"px"; style.position = "absolute"; style.top = 4*scale+"px"; style.left = 40*scale+"px"; style.cursor = "pointer"; } lockToggle.addEventListener("click", function(event) { if (!pageLocked) { pageLocked = true; (window || unsafeWindow).onbeforeunload = function() { giveMessage("FC Enhance is locked."); return "This page is locked by FC Enhance."; }; giveMessage("Page locked."); this.src = lockPic; document.cookie = "locked=yes; expires=01 Jan 2999 00:00:00 UTC; path=/"; } else { pageLocked = false; window.onbeforeunload = defaultOnBeforeUnload; //Likely a blank string, or null giveMessage("Page unlocked."); this.src = unlockPic; document.cookie = "locked=no; expires=01 Jan 2999 00:00:00 UTC; path=/"; } }); //Let's set it to locked if the cookie says so centered.appendChild(lockToggle); if (getCookie("locked") == "yes") { lockToggle.click(); lockToggle.src = lockPic; } } addLockButton(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////INFO BOX AND RATING SYSTEM/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getUseFlashVars() { //For creating the info box, now based on flashvars var fvars = contraption.getAttribute("flashvars");; //Get the type (level, design) and the id var key = fvars.split("=")[0]; if (!key) {return "No level/design to load info";} //Before we go on we should return if there is no key=value var value = fvars.split("=")[1].split("&")[0]; //We don't want to do any more if we don't have something for the type that we can deal with key = key.toUpperCase(); //For no case sensativity if (key != "LEVELID" && key != "DESIGNID") { return "Not a recognized type"; } var area = document.getElementsByClassName("centered")[0]; //First delete previous zone var prevZone = document.getElementById('zone'); if (prevZone) { area.removeChild(prevZone); } var zone = document.createElement("div"); area.appendChild(zone); //Add the zone element which we will be putting stuff inside zone.id = "zone"; var contentTitle = document.createElement("span"); contentTitle.innerHTML = "<br><br><br><h1 style = 'font-size:1em;'>Current " + (key == "DESIGNID" ? "Design" : "Level") + "</h1>"; zone.appendChild(contentTitle); //Name and author var contentName = document.createElement("span"); contentName.id = "contentName"; zone.appendChild(contentName); //This will be filled by an AJAX req later var contentAuthor = document.createElement("span"); contentAuthor.id = "contentAuthor"; zone.appendChild(contentAuthor); //This will be filled by an AJAX req later. Currently no way to do this var thumb = document.createElement("img"); thumb.id = "thumbnail"; thumb.style.width = "12%"; thumb.style.display = "block"; thumb.style.margin = "auto"; thumb.style.border = "1px solid black"; zone.appendChild(thumb); //FCR links now var links; switch (key) { case "LEVELID": links = "\ <div class = 'links'>\ <a href = 'http://fantasticcontraption.com/?levelId=" + value + "'>Reload this level</a><br />\ <a href = 'http://fc.sk89q.com/level?levelId=" + value + "'>Level on FCR</a><br />\ <a href = 'http://id36.ueuo.com/shw-dsgn-lvl.php?levelId=" + value + "'>Solutions</a><br />\ <a href = 'http://fc.sk89q.com/export?type=level&id=" + value + "&format=fcml'>FCML</a>\ </div>\ "; break; case "DESIGNID": links = "\ <div class = 'links'>\ <a id = 'playLink' href = '#'>Play this level</a><br />\ <a href = 'http://fc.sk89q.com/design?designId=" + value + "'>Design on FCR</a><br />\ <a href = 'http://fc.sk89q.com/export?type=design&id=" + value + "&format=fcml'>FCML</a>\ </div>\ "; break; } zone.innerHTML += links; with (document.getElementsByClassName('links')[0]) { style.textAlign = "left"; style.display = "inline-block"; } var emptyStarImage = ""; var fullStarImage = ""; var stars = document.createElement('div'); stars.innerHTML = "<i>Your vote is being cast for the " + (key == "LEVELID" ? "level on the right" : "design on the right") + ".</i><br />"; stars.style.display = "inline-block"; stars.style.marginLeft = -3*scale+"px"; var i; for (i = 0; i < 5; i++) { stars.innerHTML += "<img id = '" + i + "' src = '" + emptyStarImage + "' />"; } zone.appendChild(stars); for (i = 0; i < 5; i++) { document.getElementById(i).addEventListener('mouseover', function(event) { var obj = event.target; //The star that caused this var i; for (i = Number(obj.id); i >= 0; i--) { document.getElementById(i).src = fullStarImage; } }); document.getElementById(i).addEventListener('mouseout', function(event) { var obj = event.target; //The star that caused this var i; for (i = Number(obj.id); i >= 0; i--) { document.getElementById(i).src = emptyStarImage; } }); document.getElementById(i).addEventListener('click', function(event) { var rate = Number(event.target.id) + 1; //The star that caused this. Add one because star starts at 0. $.ajax({ type: "POST", url: "http://www.fantasticcontraption.com/setRating.php", data: { xml: "<setRating><" + (key == "LEVELID" ? "level" : "design") + "Id>" + value + "</" + (key == "LEVELID" ? "level" : "design") + "Id><qualityRating>" + rate + "</qualityRating><userId>" + getCookie("userid") + "</userId></setRating>" } }); giveMessage((key == "LEVELID" ? "Level" : "Design") + " rated " + rate + " " + (rate > 1 ? "stars" : "star") + "."); }); } $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/retrieveLevel.php", data: { id: value, loadDesign: (key == "DESIGNID" ? 1 : 0) }, success: function(data) { document.getElementById('contentName').innerHTML = data.getElementsByTagName('name')[0].innerHTML;// + "<br />"; document.getElementById('playLink').href = "http://fantasticcontraption.com/?levelId=" + data.getElementsByTagName('levelId')[0].innerHTML; } }); //Now let's load a screenshot if (key == "LEVELID") { GM_xmlhttpRequest({ method: "GET", dataType: "text", url: "http://id36.ueuo.com/shw-dsgn-lvl.php?levelId=" + value, onload: function(response) { parse(response); } }); } function parse(response) { srcXML = response.responseText; var dataURL = srcXML.match(/src='data:image.*?[\w=]'/g)[0]; //Match starting with the data: and ending in either an equals sign or a space. Nongreedy star. dataURL = dataURL.substring(5, dataURL.length-1); document.getElementById('thumbnail').src = dataURL; } } getUseFlashVars(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////REFRESH FLASH//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function createRefreshButton() { var refreshButton = document.createElement("img"); with (refreshButton) { id = "refreshButton"; title = "Refresh The Game!"; style.position = "absolute"; style.right = 4*scale+"px"; style.top = 4*scale+"px"; style.cursor = "pointer"; style.width = 32*scale+'px'; style.zIndex = "200"; title = "Game lagging? Click here to make it run quickly again. Does not reload the page. You will not lose your progress."; src = refreshPic; } function refreshSWF() { var contrap = getFlash(); contrap.Zoom(50); contrap.Zoom(0); giveMessage("Game refreshed."); this.blur(); //This will always work. So user doesn't reactivate upon hitting space to try to start contraption. contraption.focus(); //This only works for embed swf in IE. } refreshButton.addEventListener('click', refreshSWF); centered.appendChild(refreshButton); } createRefreshButton(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////BACKSPACE NAVIGATION PREVENTION////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// $(document).unbind('keydown').bind('keydown', function (event) { var doPrevent = false; if (event.keyCode === 8) { var d = event.srcElement || event.target; if ((d.tagName.toUpperCase() === 'INPUT' && ( d.type.toUpperCase() === 'TEXT' || d.type.toUpperCase() === 'PASSWORD' || d.type.toUpperCase() === 'FILE' || d.type.toUpperCase() === 'SEARCH' || d.type.toUpperCase() === 'EMAIL' || d.type.toUpperCase() === 'NUMBER' || d.type.toUpperCase() === 'DATE' ) ) || d.tagName.toUpperCase() === 'TEXTAREA' || d.tagName.toUpperCase() === 'EMBED' || d.tagName.toUpperCase() === 'OBJECT') { doPrevent = d.readOnly || d.disabled; } else { doPrevent = true; } } if (doPrevent) { event.preventDefault(); giveMessage("Backspace denied."); } }); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HIDE ELEMENTS ON SCROLL////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function hide(el) { if (el == centered) { //Main game section el.style.width = 1*scale+"px"; el.style.height = 1*scale+"px"; el.style.overflow = "hidden"; //Hide position:absolute children var children = el.children; for (var i = 0; i < children.length; i++) { var child = children[i]; if (child.style.position == "absolute") { child.style.display = "none"; } } } else { el.style.display = "none"; } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////SHOW PAGES ON SCROLL///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function show(el) { if (el == centered) { el.style.width = "900px"; el.style.height = "initial"; el.style.overflow = "visible"; //Show position:absolute children var children = el.children; for (var i = 0; i < children.length; i++) { var child = children[i]; if (child.style.position == "absolute") { child.style.display = "initial"; } } } else { el.style.display = "block"; } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////ADD WEBPAGES///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addPage(url, description, id, div) { var aPage = document.createElement("div"); aPage.className = "centered"; aPage.style.position = "absolute"; aPage.id = div; aPage.style.left = "0"; aPage.setAttribute("data-pagedescription", description); aPage.style.position = "absolute"; aPage.style.top = 45*scale+"px"; aPage.style.backgroundColor = "#2550FF"; aPage.style.left = "calc(50% - "+540*scale+"px)"; aPage.style.border = 15*scale+"px solid #2550FF"; aPage.style.borderRadius = 25*scale+"px"; aPage.style.height = 786.42857*scale+"px"; aPage.style.width = 1100*scale+"px"; var frame = document.createElement("iframe"); frame.src = url; frame.id = id; frame.style.height = "100%"; frame.style.width = "100%"; frame.style.backgroundColor = "#FFFFFF"; aPage.appendChild(frame); document.body.appendChild(aPage); hide(aPage); window.addEventListener("resize", function() { //This is all just to make sure the iframe resizes based on the window dimensions if (aPage == centered) return "We don't resize the main game page"; //If it is hidden, don't resize it var vw = unsafeWindow.innerWidth / 100; var vh = unsafeWindow.innerHeight / 100; }); window.dispatchEvent(new Event('resize')); //Set initial sizes based on window size } addPage("http://fc.sk89q.com/webfcml/", "FCML Editor", "editor", "editdiv"); addPage("http://id36.ueuo.com/", "Other Website", "otherSites", "otherdiv"); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////PAGE SCROLL CODE///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getNextPage(direction) { //direction="right" or "left" var pages = document.getElementsByClassName("centered"); var hub = 0; hide(pages[currentPageNumber]); if (direction == "right") { if (currentPageNumber + 1 >= pages.length) { currentPageNumber = 0; } else { currentPageNumber += 1; } } if (direction == "left") { if (currentPageNumber - 1 < 0) { currentPageNumber = pages.length - 1; } else { currentPageNumber -= 1; } } show(pages[currentPageNumber]); if (currentPageNumber == 0){ if(document.getElementById("sHubs").checked){ document.getElementById('lateHub').style.display = 'none'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'none'; //document.getElementById('cInput').style.display = 'none'; //document.getElementById('ctitle').style.display = 'none'; //document.getElementById('cSubmit').style.display = 'none'; document.getElementById('resetHub').style.display = "none"; }else{ document.getElementById('lateHub').style.display = 'block'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'block'; //document.getElementById('cInput').style.display = 'block'; //document.getElementById('ctitle').style.display = 'block'; //document.getElementById('cSubmit').style.display = 'block'; document.getElementById('resetHub').style.display = "block"; } if(document.getElementById("sLvl").checked){ document.getElementById("randLevelHub").style.display = 'none'; }else{ document.getElementById("randLevelHub").style.display = 'block'; } if(document.getElementById("sChat").checked){ document.getElementById("chatHub").style.display = 'none'; }else{ document.getElementById("chatHub").style.display = 'block'; } if(document.getElementById("sScroll").checked){ document.getElementById("leftBtn").style.display = 'none'; document.getElementById("rightBtn").style.display = 'none'; document.getElementById("pageDescription").style.display = 'none'; }else{ document.getElementById("leftBtn").style.display = 'block'; document.getElementById("rightBtn").style.display = 'block'; document.getElementById("pageDescription").style.display = 'block'; } } if (currentPageNumber != 0){ document.getElementById('chatHub').style.display = 'none'; document.getElementById('tweakBtn').src = btnOff; btnState = "Off"; document.getElementById('rArrow').style.display = 'none'; } if (currentPageNumber == 1){ document.getElementById('fcmlHub').style.display = 'block'; if(document.getElementById("editor").src == "http://fc.sk89q.com/webfcml/"){ document.getElementById('fcmlHubE').style.display = 'block'; } } if (currentPageNumber != 1){ document.getElementById('fcmlHub').style.display = 'none'; document.getElementById('fcmlHubE').style.display = 'none'; } if (currentPageNumber == 2){ document.getElementById("iframeHub").style.display = "block"; document.getElementById('rArrow').style.display = 'none'; } if (currentPageNumber != 2){ document.getElementById("iframeHub").style.display = "none"; } if (currentPageNumber < 100){ document.getElementById("leftBtn").style.display = "block"; document.getElementById("rightBtn").style.display = "block"; document.getElementById("pageDescription").style.display = "block"; document.getElementById("sHub").style.display = 'none'; } document.getElementById("pageDescription").innerHTML = pages[currentPageNumber].getAttribute("data-pagedescription"); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////SCROLL ELEMENTS////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addScrollElements() { var leftButton = document.createElement("img"); var rightButton = document.createElement("img"); var centerDescOffset = 13*scale; leftButton.style.width = 2.5*scale+"em"; rightButton.style.width = 2.5*scale+"em"; leftButton.id = "leftBtn"; rightButton.id = "rightBtn"; leftButton.style.cursor = "pointer"; rightButton.style.cursor = "pointer"; leftButton.style.position = "absolute"; rightButton.style.position = "absolute"; leftButton.style.top = 0*scale+"px"; leftButton.style.right = 275*scale+"px"; rightButton.style.top = 0*scale+"px"; rightButton.style.right = 90*scale+"px"; leftButton.src = leftArrowPic; rightButton.src = rightArrowPic; var pageName = document.createElement("div"); pageName.style.position = "absolute"; pageName.style.width = 160*scale+"px"; pageName.style.top = "0px"; pageName.style.right = 120*scale+"px"; pageName.style.fontSize = 0.9*scale+"em"; pageName.id = "pageDescription"; pageName.innerHTML = centered.getAttribute("data-pagedescription"); pageName.style.textAlign = "center"; leftButton.addEventListener("click", function() { getNextPage("left"); }); rightButton.addEventListener("click", function() { getNextPage("right"); }); centered.appendChild(leftButton); centered.appendChild(pageName); centered.appendChild(rightButton); } addScrollElements(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////TEXTFIELD BUTTON WIDGET////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addInputWidget(leftAmount, topAmount, titleText, actionText, callback) { //Add the base DIV var section = document.createElement('div'); //Create the surrounding div section.style.position = "absolute"; //Positioning section.style.top = topAmount*scale; //etc. section.style.left = leftAmount*scale; //etc. section.style.width = 284*scale+"px"; section.style.textAlign = "center"; //Center everything document.body.appendChild(section); //Add the div to the document. It will not dissapear when other pages are requested //Add a title var title = document.createElement("h4"); //Just a text element title.innerHTML = titleText; //Text to show section.appendChild(title); //Create a box to enter some input! var input = document.createElement("input"); //Create the input input.type = "text"; //Textbox input.style.padding = 5*scale+"px"; //Just some styles input.style.borderRadius = 5*scale+"px"; input.style.border = "none"; input.style.height = 30*scale+"px"; //Now create a button to save the info var submit = document.createElement("input"); //Create the button. May want to replace with an image later because images>buttons submit.type = "button"; //Button submit.value = actionText; //What the button says submit.style.marginLeft = 5*scale+"px"; submit.style.padding = 5*scale+"px"; submit.style.border = "none"; submit.style.borderRadius = 5*scale+"px"; submit.style.height = 40+scale+"px"; submit.style.cursor = "pointer"; //Set cursor to pointer, to make it obvious it is clickable input.addEventListener("keypress", function(event) { //So pressing ENTER submits the thing if (event.keyCode == 13) { submit.click(); } }); //Now create an invisible submit button so by default pressing ENTER will submit.addEventListener('click', function() { if (!input.value) return false; //If blank was entered callback(input.value); }); //Now add the things section.appendChild(input); section.appendChild(submit); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////RED ARROW BLOCKER//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function addRedArrowBlocker() { var blocker = document.createElement("div"); var boundingSWF = document.getElementById('contraption').getBoundingClientRect(); with (blocker) { style.width = 90*scale+"px"; style.height = 90*scale+"px"; style.left = (boundingSWF.right - 60*scale) + "px"; style.top = (boundingSWF.top + 15*scale) + "px"; style.backgroundImage = "url('http://i.imgur.com/FXfHqwG.png')"; style.backgroundSize= "100% auto"; style.borderRadius = 35*scale+"px"; style.position = "absolute"; style.display = "none"; style.zIndex = "200"; id = "rArrow"; } function drag(e) { var diffX = cursorOffsetX - (e.clientX - Number(blocker.style.left.split('p')[0])); var diffY = cursorOffsetY - (e.clientY - Number(blocker.style.top.split('p')[0])); var dist = Math.sqrt(Math.pow(diffX, 2) + Math.pow(diffY, 2)); if (dist > 20) { blocker.style.top = e.clientY - cursorOffsetY + "px"; blocker.style.left = e.clientX - cursorOffsetX + "px"; } } function addDrag(e) { window.addEventListener("mousemove", drag); } document.body.appendChild(blocker); blocker.addEventListener("mousedown", function(e) { cursorOffsetX = e.clientX - Number(blocker.style.left.split('p')[0]); cursorOffsetY = e.clientY - Number(blocker.style.top.split('p')[0]); addDrag(e); }); window.addEventListener("mouseup", function() { window.removeEventListener('mousemove', drag); }); } addRedArrowBlocker(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////VARIABLES FOR HUBS/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var topLvlListId = []; var topLvlListName = []; var topLvlList = []; var topLvlListDesc = []; var topLvlListQ = []; var topLvlListD = []; var topLvlListA = []; var lateLvlListId = []; var lateLvlListName = []; var lateLvlList = []; var lateLvlListDesc = []; var lateLvlListQ = []; var lateLvlListD = []; var lateLvlListA = []; var dsgId = []; var dsgName = []; var dsgUser = []; var topItr = 0; var lateItr = 0; var maxL = 5; var contHolder = ""; var lBtn = ""; var dBtn = ""; var hBtn = ""; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////LATEST HUB/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var lateHub = document.createElement("div"); lateHub.style.position = "absolute"; lateHub.style.display = "block"; lateHub.style.borderStyle = "solid"; lateHub.style.borderRadius = 25*scale+"px"; lateHub.style.borderColor = "blue"; lateHub.style.top = 48*scale+"px"; lateHub.style.left = 20*scale+"px"; lateHub.style.backgroundColor = "#85B6F0"; lateHub.style.width = locationBox.left - 50+"px"; if(locationBox.left - 50 > 320){ lateHub.style.width = "320px" } lateHub.style.height="85%"; lateHub.id = "lateHub"; lateHub.innerHTML = "<img src ='http://i68.tinypic.com/2m5hvh1.gif' width='100%' title= 'Switch to Top Levels' id='displayTop'>"; lateHub.style.overflow = "hidden"; centered.appendChild(lateHub); //------Create Area where Levels Generate var lateInnerHub = document.createElement("div"); lateInnerHub.style.position = "absolute"; lateInnerHub.id = "lateInnerHub"; lateInnerHub.style.width = locationBox.left - 50+"px"; if(locationBox.left - 50 > 320){ lateInnerHub.style.width = "320px" } lateInnerHub.style.overflowY = "scroll"; lateInnerHub.style.overflowX = "hidden"; lateInnerHub.style.maxHeight="85%"; lateInnerHub.style.paddingRight = 20*scale+"px"; lateHub.appendChild(lateInnerHub); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////TOP HUB////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var TopHub = document.createElement("div"); TopHub.style.position = "absolute"; TopHub.style.display = "none"; TopHub.style.borderStyle = "solid"; TopHub.style.borderRadius = 25*scale+"px"; TopHub.style.borderColor = "blue"; TopHub.style.top = 48*scale+"px"; TopHub.style.left = 20+scale+"px"; TopHub.style.backgroundColor = "#85B6F0"; TopHub.style.width = locationBox.left - 50+"px"; TopHub.style.overflow = "hidden"; if(locationBox.left - 50 > 320){ TopHub.style.width = "320px" } TopHub.style.height="85%"; TopHub.id = "TopHub"; TopHub.innerHTML = "<img src='http://i63.tinypic.com/2uixhg8.gif' width='100%' title='Switch to Latest Levels' id='displayLatest'>"; centered.appendChild(TopHub); //-----Create area where levels generate var lateTopHub = document.createElement("div"); lateTopHub.style.position = "absolute"; lateTopHub.id = "TopInnerHub"; lateTopHub.style.overflowY = "auto"; lateTopHub.style.overflowX = "hidden"; lateTopHub.style.paddingRight = 20*scale+"px"; lateTopHub.style.width = locationBox.left - 50+"px"; if(locationBox.left - 50 > 320){ lateTopHub.style.width = "320px" } lateTopHub.style.maxHeight="85%"; TopHub.appendChild(lateTopHub); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////DESIGN HUB/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var dsgHub = document.createElement("div"); dsgHub.style.position = "absolute"; dsgHub.style.display = "none"; //dsgHub.style.zIndex = "-1"; dsgHub.style.borderStyle = "solid"; dsgHub.style.borderRadius = "25px"; dsgHub.style.borderColor = "blue"; dsgHub.style.backgroundColor = "#85B6F0"; dsgHub.style.top = 48*scale+"px"; dsgHub.style.left = 20*scale+"px"; dsgHub.style.overflow = "hidden"; dsgHub.style.width = locationBox.left - 50+"px"; if(locationBox.left - 50 > 320){ dsgHub.style.width = "320px" } dsgHub.style.height="85%"; dsgHub.id = "dsgHub"; dsgHub.innerHTML = "<img src='http://i67.tinypic.com/imjmzo.gif' width='100%' title='Click to go Back' id='backBtn'>"; centered.appendChild(dsgHub); //-----Create area where designs generate var dsgInnerHub = document.createElement("div"); dsgInnerHub.style.position = "absolute"; dsgInnerHub.id = "dsgInnerHub"; dsgInnerHub.style.overflowY = "auto"; dsgInnerHub.style.overflowX = "hidden"; dsgInnerHub.style.paddingRight = 20*scale+"px"; dsgInnerHub.style.maxHeight="85%"; dsgInnerHub.style.width = locationBox.left - 50+"px"; if(locationBox.left - 50 > 320){ dsgInnerHub.style.width = "320px" } dsgInnerHub.style.textAlign="left"; dsgHub.appendChild(dsgInnerHub); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HUB TOGGLE CODE////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// document.getElementById("displayLatest").onclick = function(){ document.getElementById('lateHub').style.display = 'block'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; }; document.getElementById("displayTop").onclick = function(){ document.getElementById('TopHub').style.display = 'block'; document.getElementById('lateHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; }; document.getElementById("backBtn").onclick = function(){ document.getElementById('lateHub').style.display = 'block'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; }; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HUB REFRESH BUTTON/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var reset = document.createElement("input"); reset.type = "image"; reset.src = hBtn; reset.title = "Reset Hub"; reset.style.height = 40*scale+"px"; reset.style.width = 40*scale+"px"; reset.style.padding = "0px"; reset.id = "resetHub"; reset.style.position = "absolute"; reset.style.top = "0px"; reset.style.left = 72*scale+"px"; reset.style.display = "none"; centered.appendChild(reset); document.getElementById("resetHub").onclick = function(){ if (pageLocked) { giveMessage("You cannot do that while the page is locked."); } else { var r = confirm("Refreshing the Hub will refresh the game. All current designs will be lost. Are you sure you want to continue?"); if(r == true){ var hMany = prompt("How many levels per hub?\nOn page load, this is 5."); if(hMany){ if(!isNaN(hMany) && hMany > 0 && hMany < 101 && hMany % 1 === 0){ maxL = hMany; contHolder = ctr.innerHTML; document.getElementsByClassName("border")[0].style.backgroundImage = "url('http://fantasticcontraption.com/images/fantastic_contraption_border.png')"; ctr.innerHTML = "<center><br><br><h1>Please Wait While Hubs Load</h1><br><br><h2>This may take a minute depending on the size of the levels.<br>Thank you for your patience!</h2><br><br><br><h4>--FC Enhance Development Team</h4></center>"; lateItr = 0; topItr = 0; resetHub(); }else{ alert("Please Enter a Number between 1-100!"); } } }else{ giveMessage("The Hub Was Not Refreshed"); } } }; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////SETTINGS BOX///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var settingFC = document.createElement("input"); settingFC.type = "image"; settingFC.src = settingsBtn; settingFC.title = "Settings"; settingFC.style.height = 40*scale+"px"; settingFC.style.width = 40*scale+"px"; settingFC.style.padding = "0px"; settingFC.id = "settingsHub"; settingFC.style.position = "absolute"; settingFC.style.top = "0px"; settingFC.style.right = 45*scale+"px"; centered.appendChild(settingFC); var sHub = document.createElement("div"); sHub.style.position = "absolute"; sHub.id = "sHub"; sHub.style.top = "0px"; sHub.style.left = 25*scale+"%"; sHub.style.zIndex = "202"; sHub.style.height = "234px"; sHub.style.width = "900px"; sHub.style.backgroundSize="cover"; sHub.style.backgroundImage = "url('http://i.imgur.com/UIFAk04.png')"; sHub.style.display = "none"; sHub.class = "centered"; centered.appendChild(sHub); document.getElementById("settingsHub").onclick = function (){ if (sHub.style.display == "none"){ sHub.style.display = "block"; }else{ sHub.style.display = "none"; } }; sHub.innerHTML = '<br><form action="" id="sForm"><h1>Hide Features On Page</h1><br><input type="checkbox" value="hubs" id="sHubs">Level Hubs <input type="checkbox" value="rLvl" id="sLvl">Random Level Hub <input type="checkbox" value="chat" id="sChat">Chat Hub <input type="checkbox" value="lvlScroll" id="sScroll">Feature Scroll</form>'; //Start doing stuff when boxes are checked document.getElementById("sHubs").onclick = function (){ if(document.getElementById("sHubs").checked){ document.getElementById('lateHub').style.display = 'none'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'none'; //document.getElementById('cInput').style.display = 'none'; //document.getElementById('ctitle').style.display = 'none'; //document.getElementById('cSubmit').style.display = 'none'; document.getElementById('resetHub').style.display = "none"; }else{ document.getElementById('lateHub').style.display = 'block'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'block'; //document.getElementById('cInput').style.display = 'block'; //document.getElementById('ctitle').style.display = 'block'; //document.getElementById('cSubmit').style.display = 'block'; document.getElementById('resetHub').style.display = "block"; } }; document.getElementById("sLvl").onclick = function (){ if(document.getElementById("sLvl").checked){ document.getElementById("randLevelHub").style.display = 'none'; }else{ document.getElementById("randLevelHub").style.display = 'block'; } }; document.getElementById("sChat").onclick = function (){ if(document.getElementById("sChat").checked){ document.getElementById("chatHub").style.display = 'none'; }else{ document.getElementById("chatHub").style.display = 'block'; } }; document.getElementById("sScroll").onclick = function (){ if(document.getElementById("sScroll").checked){ document.getElementById("leftBtn").style.display = 'none'; document.getElementById("rightBtn").style.display = 'none'; document.getElementById("pageDescription").style.display = 'none'; }else{ document.getElementById("leftBtn").style.display = 'block'; document.getElementById("rightBtn").style.display = 'block'; document.getElementById("pageDescription").style.display = 'block'; } }; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FCML EXPORT HUB////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var fcmlHub = document.createElement("div"); fcmlHub.style.position = "absolute"; fcmlHub.style.display = "none"; fcmlHub.style.borderStyle = "solid"; fcmlHub.style.borderRadius = 25*scale+"px"; fcmlHub.style.borderColor = "blue"; fcmlHub.style.backgroundImage = "url('http://i67.tinypic.com/w6w514.jpg')"; fcmlHub.style.top = 48*scale+"px"; fcmlHub.style.right = 20*scale+"px"; fcmlHub.style.width = 320*scale+"px"; fcmlHub.style.height="85%"; fcmlHub.id = "fcmlHub"; centered.appendChild(fcmlHub); fcmlHub.innerHTML = "<center><div id = 'fcmlInnerHub'><h1>FCML EXPORT HUB</h1></div><center>"; document.getElementById("fcmlInnerHub").style.height = "100%"; document.getElementById("fcmlInnerHub").style.overflowY = "auto"; var exportInput = document.createElement("input"); exportInput.type = "text"; exportInput.id = "exportInput"; exportInput.style.width = "95%"; exportInput.style.borderRadius = 5*scale+"px"; exportInput.style.border = 5*scale+"px"; exportInput.style.textAlign = "center"; exportInput.style.height = 30*scale+"px"; document.getElementById("fcmlInnerHub").appendChild(exportInput); var exportButton = document.createElement("input"); exportButton.type = "submit"; exportButton.id = "exportButton"; exportButton.style.width = "95%"; exportButton.style.borderRadius = 5*scale+"px"; exportButton.style.border = 5*scale+"px"; exportButton.value = "Enter Level ID and Click for FCML Export"; document.getElementById("fcmlInnerHub").appendChild(exportButton); var exportFrame = document.createElement("iframe"); exportFrame.id = "exportFrame"; exportFrame.src = ""; exportFrame.width = "90%"; exportFrame.height = 575*scale+"px"; exportFrame.style.overflowY = "auto"; document.getElementById("fcmlInnerHub").appendChild(exportFrame); var exportClear = document.createElement("input"); exportClear.type = "submit"; exportClear.id = "exportClear"; exportClear.style.width = "95%"; exportClear.value = "Clear FCML"; exportClear.style.borderRadius = 5*scale+"px"; exportClear.style.border = 5*scale+"px"; exportClear.style.display = "none"; document.getElementById("fcmlInnerHub").appendChild(exportClear); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////EDITOR TOGGLE BUTTON///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var switchEditor = document.createElement("input"); switchEditor.type = "submit"; switchEditor.id = "switchEditor"; switchEditor.style.width = "95%"; switchEditor.style.height= '30px'; switchEditor.style.margin = "5px"; switchEditor.value = "Switch Editors"; switchEditor.style.borderRadius = 5*scale+"px"; switchEditor.style.border = 5*scale+"px"; document.getElementById("fcmlHub").appendChild(switchEditor); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FCML EXPORT////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// document.getElementById("exportButton").onclick = function() { var exportId = document.getElementById("exportInput").value; if (exportId % 1 === 0 && !isNaN(exportId) && exportId.length > 0){ $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/retrieveLevel.php", data: { id: exportId, }, error: function(data){ alert("Unabale to load FCML for ID: "+exportId+" due to corrupted level data!\nIf you feel this is an error, please contact FC Enhance development team."); document.getElementById("exportFrame").src = ""; }, success: function(data) { var x = data.getElementsByTagName('levelId'); var y = x[0].innerHTML; if(y == exportId){ document.getElementById("exportFrame").src = "http://fc.sk89q.com/export?type=level&id=" + exportId + "&format=fcml"; document.getElementById("exportFrame").style.backgroundColor = "#87BEF1"; document.getElementById("exportClear").style.display = "block"; }else{ alert("ID does not Exist!"); document.getElementById("exportFrame").src = ""; } } }); }else{ alert("Please Enter A Valid ID!"); } }; //Do stuff to clear FCML document.getElementById("exportClear").onclick = function() { document.getElementById("exportFrame").src = ""; document.getElementById("exportFrame").style.backgroundColor = ""; document.getElementById("exportClear").style.display = "none"; document.getElementById("exportInput").value = ""; }; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////SWITCH EDITORS/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// document.getElementById("switchEditor").onclick = function() { var currentEditor = document.getElementById("editor").src; var conf = confirm("Switching Editors Will Result In Loss of Work!\n\n Do You Wish To Continue?"); if(conf){ if(currentEditor == "http://fc.sk89q.com/webfcml/"){ document.getElementById("fcmlInnerHub").style.display = 'none'; document.getElementById("fcmlHub").style.height = '35px'; document.getElementById("fcmlHubE").style.display = 'none'; document.getElementById("editor").src = 'http://editor.eu5.org/'; document.getElementById("editdiv").style.left = "calc(50% - "+840*scale+"px)"; document.getElementById("editdiv").style.width = 1400*scale+"px"; }else{ document.getElementById("fcmlHub").style.height = '85%'; document.getElementById("fcmlInnerHub").style.display = 'block'; document.getElementById("fcmlHubE").style.display = 'block'; document.getElementById("editor").src = 'http://fc.sk89q.com/webfcml/'; document.getElementById("editdiv").style.left = "calc(50% - "+540*scale+"px)"; document.getElementById("editdiv").style.width = 1100*scale+"px"; } } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FCML CONVERSION HUB////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var fcmlHubE = document.createElement("div"); fcmlHubE.style.position = "absolute"; fcmlHubE.style.display = "none"; fcmlHubE.style.borderStyle = "solid"; fcmlHubE.style.borderRadius = 25*scale+"px"; fcmlHubE.style.borderColor = "blue"; fcmlHubE.style.backgroundImage = "url('http://i67.tinypic.com/w6w514.jpg')"; fcmlHubE.style.top = 48*scale+"px"; fcmlHubE.style.left = 20*scale+"px"; fcmlHubE.style.width = 360*scale+"px"; fcmlHubE.style.height="85%"; fcmlHubE.id = "fcmlHubE"; centered.appendChild(fcmlHubE); fcmlHubE.innerHTML = "<center><div id = 'fcmlInnerHubE'><h1>FCML Special Piece Conversion</h1></div><center>"; document.getElementById("fcmlInnerHubE").style.height = "100%"; document.getElementById("fcmlInnerHubE").style.width = "90%"; document.getElementById("fcmlInnerHubE").style.overflowY = "auto"; var hr1 = document.createElement("hr"); hr1.style.borderStyle = "inset"; hr1.style.borderWidth = 5*scale+"px"; hr1.style.borderColor = "#87BEF1"; document.getElementById("fcmlInnerHubE").appendChild(hr1); var pgpTitle = document.createElement("h4"); //Just a text element pgpTitle.innerHTML = "Powered wheels ➞ Powered goal pieces"; //Text to show pgpTitle.id = "pgpTitle"; document.getElementById("fcmlInnerHubE").appendChild(pgpTitle); var exportPGP = document.createElement("input"); exportPGP.type = "text"; exportPGP.value = "Enter an ID"; exportPGP.id = "exportPGP"; exportPGP.style.width = "35%"; exportPGP.style.borderRadius = 5*scale+"px"; exportPGP.style.border = 5*scale+"px"; exportPGP.style.textAlign = "center"; exportPGP.style.height = 20*scale+"px"; document.getElementById("fcmlInnerHubE").appendChild(exportPGP); var PGPButton = document.createElement("input"); PGPButton.type = "submit"; PGPButton.id = "PGPButton"; PGPButton.style.borderRadius = 5*scale+"px"; PGPButton.style.border = 5*scale+"px"; PGPButton.value = "Convert!"; PGPButton.style.height = 20*scale+"px"; document.getElementById("fcmlInnerHubE").appendChild(PGPButton); var exportPGP2 = document.createElement("input"); exportPGP2.type = "text"; exportPGP2.id = "exportPGP2"; exportPGP2.style.width = "35%"; exportPGP2.style.borderRadius = 5*scale+"px"; exportPGP2.style.border = 5*scale+"px"; exportPGP2.style.textAlign = "center"; exportPGP2.style.height = 20*scale+"px"; document.getElementById("fcmlInnerHubE").appendChild(exportPGP2); document.getElementById("PGPButton").onclick = function(){ var levelId = document.getElementById("exportPGP").value; if (levelId % 1 === 0 && !isNaN(levelId) && levelId.length > 0){ GM_xmlhttpRequest({ method: "POST", dataType: "xml", url: "http://id36.ueuo.com/ver-fcml-pgp.php", data: "levelid="+levelId+"", headers: { "Content-Type": "application/x-www-form-urlencoded" }, onload: function(response) { var x = response.responseText; var y = x.match(/<div.+?(?=<\/div>)/g); if(y){ x = x.split(y[0]).pop(); x = x.split("<img").pop(); x = x.split("</div>").pop(); x.split("\n").pop(); document.getElementById("exportPGP2").value = x; document.getElementById("exportPGP").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportPGP").value = "Enter an ID"; }, 1000); }else{ document.getElementById("exportPGP2").value = x; document.getElementById("exportPGP").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportPGP").value = "Enter an ID"; }, 1000); } } }); }else{ alert("Please Enter A Valid ID!"); } }; var PinTitle = document.createElement("h4"); //Just a text element PinTitle.innerHTML = "(Powered) wheels ➞ Pins"; //Text to show PinTitle.id = "PinTitle"; document.getElementById("fcmlInnerHubE").appendChild(PinTitle); var exportPin = document.createElement("input"); exportPin.type = "text"; exportPin.value = "Enter an ID"; exportPin.id = "exportPin"; exportPin.style.width = "35%"; exportPin.style.borderRadius = 5*scale+"px"; exportPin.style.border = 5*scale+"px"; exportPin.style.textAlign = "center"; exportPin.style.height = 20*scale+"px"; document.getElementById("fcmlInnerHubE").appendChild(exportPin); var PinButton = document.createElement("input"); PinButton.type = "submit"; PinButton.id = "PinButton"; PinButton.style.borderRadius = 5*scale+"px"; PinButton.style.border = 5*scale+"px"; PinButton.value = "Convert!"; PinButton.style.height = 20*scale+"px"; document.getElementById("fcmlInnerHubE").appendChild(PinButton); var exportPin2 = document.createElement("input"); exportPin2.type = "text"; exportPin2.id = "exportPin2"; exportPin2.style.width = "35%"; exportPin2.style.borderRadius = 5*scale+"px"; exportPin2.style.border = 5*scale+"px"; exportPin2.style.textAlign = "center"; exportPin2.style.height = 20*scale+"px"; document.getElementById("fcmlInnerHubE").appendChild(exportPin2); document.getElementById("PinButton").onclick = function(){ var levelId = document.getElementById("exportPin").value; if (levelId % 1 === 0 && !isNaN(levelId) && levelId.length > 0){ GM_xmlhttpRequest({ method: "POST", dataType: "xml", url: "http://id36.ueuo.com/ver-fcml-pin.php", data: "levelid="+levelId+"", headers: { "Content-Type": "application/x-www-form-urlencoded" }, onload: function(response) { var x = response.responseText; var y = x.match(/<div.+?(?=<\/div>)/g); if(y){ x = x.split(y[0]).pop(); x = x.split("<img").pop(); x = x.split("</div>").pop(); x.split("\n").pop(); document.getElementById("exportPin2").value = x; document.getElementById("exportPin").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportPin").value = "Enter an ID"; }, 1000); }else{ document.getElementById("exportPin2").value = x; document.getElementById("exportPin").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportPin").value = "Enter an ID"; }, 1000); } } }); }else{ alert("Please Enter A Valid ID!"); } }; var GhostTitle = document.createElement("h4"); //Just a text element GhostTitle.innerHTML = "Dynamic pieces ➞ Ghost pieces"; //Text to show GhostTitle.id = "GhostTitle"; document.getElementById("fcmlInnerHubE").appendChild(GhostTitle); var exportGhost = document.createElement("input"); exportGhost.type = "text"; exportGhost.value = "Enter an ID"; exportGhost.id = "exportGhost"; exportGhost.style.width = "35%"; exportGhost.style.borderRadius = "5px"; exportGhost.style.border = "5px"; exportGhost.style.textAlign = "center"; exportGhost.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(exportGhost); var GhostButton = document.createElement("input"); GhostButton.type = "submit"; GhostButton.id = "GhostButton"; GhostButton.style.borderRadius = "5px"; GhostButton.style.border = "5px"; GhostButton.value = "Convert!"; GhostButton.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(GhostButton); var exportGhost2 = document.createElement("input"); exportGhost2.type = "text"; exportGhost2.id = "exportGhost2"; exportGhost2.style.width = "35%"; exportGhost2.style.borderRadius = "5px"; exportGhost2.style.border = "5px"; exportGhost2.style.textAlign = "center"; exportGhost2.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(exportGhost2); document.getElementById("GhostButton").onclick = function(){ var levelId = document.getElementById("exportGhost").value; if (levelId % 1 === 0 && !isNaN(levelId) && levelId.length > 0){ GM_xmlhttpRequest({ method: "POST", dataType: "xml", url: "http://id36.ueuo.com/ver-fcml-dgp.php", data: "levelid="+levelId+"", headers: { "Content-Type": "application/x-www-form-urlencoded" }, onload: function(response) { var x = response.responseText; var y = x.match(/<div.+?(?=<\/div>)/g); if(y){ x = x.split(y[0]).pop(); x = x.split("<img").pop(); x = x.split("</div>").pop(); x.split("\n").pop(); document.getElementById("exportGhost2").value = x; document.getElementById("exportGhost").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportGhost").value = "Enter an ID"; }, 1000); }else{ document.getElementById("exportGhost2").value = x; document.getElementById("exportGhost").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportGhost").value = "Enter an ID"; }, 1000); } } }); }else{ alert("Please Enter A Valid ID!"); } }; var PhantomTitle = document.createElement("h4"); //Just a text element PhantomTitle.innerHTML = "Static pieces ➞ Phantom pieces"; //Text to show PhantomTitle.id = "PhantomTitle"; document.getElementById("fcmlInnerHubE").appendChild(PhantomTitle); var exportPhantom = document.createElement("input"); exportPhantom.type = "text"; exportPhantom.value = "Enter an ID"; exportPhantom.id = "exportPhantom"; exportPhantom.style.width = "35%"; exportPhantom.style.borderRadius = "5px"; exportPhantom.style.border = "5px"; exportPhantom.style.textAlign = "center"; exportPhantom.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(exportPhantom); var PhantomButton = document.createElement("input"); PhantomButton.type = "submit"; PhantomButton.id = "PhantomButton"; PhantomButton.style.borderRadius = "5px"; PhantomButton.style.border = "5px"; PhantomButton.value = "Convert!"; PhantomButton.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(PhantomButton); var exportPhantom2 = document.createElement("input"); exportPhantom2.type = "text"; exportPhantom2.id = "exportPhantom2"; exportPhantom2.style.width = "35%"; exportPhantom2.style.borderRadius = "5px"; exportPhantom2.style.border = "5px"; exportPhantom2.style.textAlign = "center"; exportPhantom2.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(exportPhantom2); document.getElementById("PhantomButton").onclick = function(){ var levelId = document.getElementById("exportPhantom").value; if (levelId % 1 === 0 && !isNaN(levelId) && levelId.length > 0){ GM_xmlhttpRequest({ method: "POST", dataType: "xml", url: "http://id36.ueuo.com/ver-fcml-spp.php", data: "levelid="+levelId+"", headers: { "Content-Type": "application/x-www-form-urlencoded" }, onload: function(response) { var x = response.responseText; var y = x.match(/<div.+?(?=<\/div>)/g); if(y){ x = x.split(y[0]).pop(); x = x.split("<img").pop(); x = x.split("</div>").pop(); x.split("\n").pop(); document.getElementById("exportPhantom2").value = x; document.getElementById("exportPhantom").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportPhantom").value = "Enter an ID"; }, 1000); }else{ document.getElementById("exportPhantom2").value = x; document.getElementById("exportPhantom").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportPhantom").value = "Enter an ID"; }, 1000); } } }); }else{ alert("Please Enter A Valid ID!"); } }; var NinjaTitle = document.createElement("h4"); //Just a text element NinjaTitle.innerHTML = "Static pieces ➞ Ninja pieces"; //Text to show NinjaTitle.id = "NinjaTitle"; document.getElementById("fcmlInnerHubE").appendChild(NinjaTitle); var exportNinja = document.createElement("input"); exportNinja.type = "text"; exportNinja.value = "Enter an ID"; exportNinja.id = "exportNinja"; exportNinja.style.width = "35%"; exportNinja.style.borderRadius = "5px"; exportNinja.style.border = "5px"; exportNinja.style.textAlign = "center"; exportNinja.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(exportNinja); var NinjaButton = document.createElement("input"); NinjaButton.type = "submit"; NinjaButton.id = "NinjaButton"; NinjaButton.style.borderRadius = "5px"; NinjaButton.style.border = "5px"; NinjaButton.value = "Convert!"; NinjaButton.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(NinjaButton); var exportNinja2 = document.createElement("input"); exportNinja2.type = "text"; exportNinja2.id = "exportNinja2"; exportNinja2.style.width = "35%"; exportNinja2.style.borderRadius = "5px"; exportNinja2.style.border = "5px"; exportNinja2.style.textAlign = "center"; exportNinja2.style.height = "20px"; document.getElementById("fcmlInnerHubE").appendChild(exportNinja2); document.getElementById("NinjaButton").onclick = function(){ var levelId = document.getElementById("exportNinja").value; if (levelId % 1 === 0 && !isNaN(levelId) && levelId.length > 0){ GM_xmlhttpRequest({ method: "POST", dataType: "xml", url: "http://id36.ueuo.com/ver-fcml-snp.php", data: "levelid="+levelId+"", headers: { "Content-Type": "application/x-www-form-urlencoded" }, onload: function(response) { var x = response.responseText; var y = x.match(/<div.+?(?=<\/div>)/g); if(y){ x = x.split(y[0]).pop(); x = x.split("<img").pop(); x = x.split("</div>").pop(); x.split("\n").pop(); document.getElementById("exportNinja2").value = x; document.getElementById("exportNinja").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportNinja").value = "Enter an ID"; }, 1000); }else{ document.getElementById("exportNinja2").value = x; document.getElementById("exportNinja").value = "SUCCESS!!!!"; setTimeout(function(){ document.getElementById("exportNinja").value = "Enter an ID"; }, 1000); } } }); }else{ alert("Please Enter A Valid ID!"); } }; var hr2 = document.createElement("hr"); hr2.style.borderStyle = "inset"; hr2.style.borderWidth = "5px"; hr2.style.borderColor = "#87BEF1"; document.getElementById("fcmlInnerHubE").appendChild(hr2); var noteTitle = document.createElement("h4"); //Just a text element noteTitle.innerHTML = "Note: For more information on pieces, how the convertors work, and the requirements for the conversions please visit ID36's website at <a href='http://id36.ueuo.com/fcml-conv.php' target='_blank'>http://id36.ueuo.com/fcml-conv.php</a><br><br>All credit to the FCML conversions go to ID36 and all parties involved in its creation. This hub is merely an ease of access used in the addon."; //Text to show noteTitle.id = "noteTitle"; document.getElementById("fcmlInnerHubE").appendChild(noteTitle); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////OTHER RESOURCE IFRAME//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var iframeHub = document.createElement("div"); iframeHub.style.position = "absolute"; iframeHub.style.display = "none"; iframeHub.style.borderStyle = "solid"; iframeHub.style.borderRadius = 25*scale+"px"; iframeHub.style.borderColor = "blue"; iframeHub.style.backgroundImage = "url('http://i67.tinypic.com/w6w514.jpg')"; iframeHub.style.top = 48*scale+"px"; iframeHub.style.right = 20*scale+"px"; iframeHub.style.width = 320*scale+"px"; iframeHub.style.height="85%"; iframeHub.id = "iframeHub"; centered.appendChild(iframeHub); iframeHub.innerHTML = "<center><div id = 'iframeInnerHub'><h1>Other Website Hub</h1></div><center>"; document.getElementById("iframeInnerHub").style.height = "100%"; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////ID36 BUTTON////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var id36Button = document.createElement("input"); id36Button.type = "image"; id36Button.id = "id36Button"; id36Button.src = "http://i.imgur.com/iGWIDjI.gif"; id36Button.style.width = "85%"; id36Button.style.borderRadius = "5px"; id36Button.style.border = "5px"; id36Button.value = "ID36's Website"; document.getElementById("iframeInnerHub").appendChild(id36Button); var br = document.createElement("br"); document.getElementById("iframeInnerHub").appendChild(br); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FCR BUTTON/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var fcrButton = document.createElement("input"); fcrButton.type = "image"; fcrButton.id = "fcrButton"; fcrButton.style.width = "85%"; fcrButton.style.borderRadius = "5px"; fcrButton.style.border = "5px"; fcrButton.value = "Fantastic Contraption Resource"; fcrButton.src = "http://i.imgur.com/3KHnMxW.gif"; document.getElementById("iframeInnerHub").appendChild(fcrButton); document.getElementById("iframeInnerHub").appendChild(br); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FORUM BUTTON///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var forumButton = document.createElement("input"); forumButton.type = "image"; forumButton.id = "forumButton"; forumButton.style.width = "85%"; forumButton.style.borderRadius = "5px"; forumButton.style.border = "5px"; forumButton.value = "Fantastic Contraption Resource"; forumButton.src = "http://i.imgur.com/ahpcfYU.gif"; document.getElementById("iframeInnerHub").appendChild(forumButton); document.getElementById("iframeInnerHub").appendChild(br); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FEEDBACK BUTTON////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var feedbackButton = document.createElement("input"); feedbackButton.type = "image"; feedbackButton.id = "feedbackButton"; feedbackButton.style.width = "85%"; feedbackButton.style.borderRadius = "5px"; feedbackButton.style.border = "5px"; feedbackButton.value = "Fantastic Contraption Resource"; feedbackButton.src = "http://i.imgur.com/Y9EgMW6.gif"; document.getElementById("iframeInnerHub").appendChild(feedbackButton); document.getElementById("iframeInnerHub").appendChild(br); document.getElementById("id36Button").onclick = function(){ document.getElementById("otherSites").src = "http://id36.ueuo.com/index.php"; }; document.getElementById("fcrButton").onclick = function(){ document.getElementById("otherSites").src = "http://fc.sk89q.com/"; }; document.getElementById("forumButton").onclick = function(){ document.getElementById("otherSites").src = "http://fc2.boards.net/"; }; document.getElementById("feedbackButton").onclick = function(){ document.getElementById("otherSites").src = "http://fc2.boards.net/conversation/new/110,12,96,3"; }; /* //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HUB REFRESH AREA///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var cAmt = document.createElement("div"); cAmt.style.position = "absolute"; cAmt.id = "cAmt"; cAmt.style.top="89%"; cAmt.style.left=10*scale+"px"; cAmt.style.textAlign="left"; centered.appendChild(cAmt); var ctitle = document.createElement("h4"); //Just a text element ctitle.innerHTML = "<center><table><tr><td> </td><td>Change How Many Levels <br>Per Hub To Load:</td></tr></table></center>"; //Text to show ctitle.id = "ctitle"; ctitle.style.fontSize = 0.9*scale+"em"; ctitle.style.display = "none"; document.getElementById("cAmt").appendChild(ctitle); //Must use the id and not the variable name becaue if changingNick the var is not defined //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HUB REFRESH INPUT//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var cInput = document.createElement("input"); //Create the input cInput.type = "number"; //Textbox cInput.id = "cInput"; cInput.style.padding = "5px"; //Just some styles cInput.style.borderRadius = "5px"; cInput.style.border = "none"; cInput.style.display = "none"; cInput.style.height = 30*scale+"px"; cInput.style.width = 45*scale+"px"; cInput.style.position = "absolute"; cInput.style.top="95%"; cInput.style.left=64*scale+"px"; centered.appendChild(cInput); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HUB REFRESH BUTTON/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var cSubmit = document.createElement("input"); //Create the button. May want to replace with an image later because images>buttons cSubmit.type = "button"; //Button cSubmit.value = "Go!"; //What the button says cSubmit.id = "cSubmit"; cSubmit.style.marginLeft = "5px"; cSubmit.style.padding = "5px"; cSubmit.style.display = "none"; cSubmit.style.border = "none"; cSubmit.style.borderRadius = "5px"; cSubmit.style.position = "absolute"; cSubmit.style.top="95%"; cSubmit.style.left=120*scale+"px"; cSubmit.style.height = 40*scale+"px"; cSubmit.style.cursor = "pointer"; //Set cursor to pointer, to make it obvious it is clickable centered.appendChild(cSubmit); document.getElementById("cSubmit").onclick = function(){ var hMany = document.getElementById("cInput").value; if(!isNaN(hMany) && hMany > 0 && hMany < 101 && hMany % 1 === 0){ if (pageLocked) { giveMessage("You cannot do that while the page is locked."); } else { var r = confirm("Refreshing the Hub will refresh the game. All current designs will be lost. Are you sure you want to continue?"); if(r == true){ maxL = hMany; contHolder = ctr.innerHTML; ctr.innerHTML = "<center><br><br><h1>Please Wait While Hubs Load</h1><br><br><h2>This may take a minute depending on the size of the levels.<br>Thank you for your patience!</h2><br><br><br><h4>--FC Enhance Development Team</h4></center>"; lateItr = 0; topItr = 0; //t = new Date(); //console.log(t); document.getElementById('dsgHub').style.display = 'none'; document.getElementById('lateHub').style.display = 'block'; document.getElementById('TopHub').style.display = 'none'; resetHub(); }else{ giveMessage("The Hub Was Not Refreshed"); } } }else{ alert("Please Enter a Number between 1-100!"); } }; */ //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////HIDE SWF WHILE HUBS LOAD///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var ctr = document.getElementById("maincontent"); contHolder = ctr.innerHTML; document.getElementsByClassName("border")[0].style.backgroundImage = "url('http://fantasticcontraption.com/images/fantastic_contraption_border.png')"; ctr.innerHTML = "<center><br><br><h1>Please Wait While Hubs Load</h1><br><br><h2>This may take a minute depending on the size of the levels.<br>Thank you for your patience!</h2><br><br><br><h4>--FC Enhance Development Team</h4></center>"; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////LOAD SWF WHEN HUBS LOAD////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function hubsLoaded(){ if(topItr == maxL && lateItr == maxL){ ctr.innerHTML = contHolder; contraption = getFlash(); if(inFullScreen){ document.getElementsByClassName("border")[0].style.backgroundImage = "url('')"; } getUseFlashVars(); if(currentPageNumber == 0){ reset.style.display = "block"; //ctitle.style.display = "block"; //cSubmit.style.display = "block"; //cInput.style.display = "block"; } setTimeout(function(){ document.elementFromPoint(10*scale, 10*scale).click(); }, 0.1); document.elementFromPoint(10*scale, 10*scale).click(); contraption=getFlash(); getUseFlashVars(); } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////KEYDOWN CODING/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var trueFull = false; var oldW; var oldH; var checkHub; var checkLvl; var checkChat; var checkScroll; var swfZ = false; function KeyPress(e) { //SHIFT + LEFT ARROW if(e.keyCode == 37 && e.shiftKey == true){ if(!trueFull){ getNextPage("left"); }else{ giveMessage("Can't Do This In FullScreen Mode!"); } } //SHIFT + RIGHT ARROW if(e.keyCode == 39 && e.shiftKey == true){ if(!trueFull){ getNextPage("right"); }else{ giveMessage("Can't Do This In FullScreen Mode!"); } } //SWF Z-INDEX //CTRL + SHIFT + UP ARROW //SET Z-INDEX to 199 OR BACK TO ORIGINAL if (e.keyCode == 38 && e.shiftKey == true && (e.ctrlKey == true || e.metaKey == true)){ var gameDiv = document.getElementsByTagName("embed"); //var gameBorder = document.getElementsByClassName("border"); //var gameDiv = document.getElementsByClassName("border"); //console.log(gameDiv[0]); if(swfZ){ gameDiv[0].style.zIndex = "auto"; //gameBorder[0].style.zIndex = "auto"; //console.log("back"); swfZ = false; }else{ gameDiv[0].style.zIndex = "199"; //gameBorder[0].style.zIndex = "199"; //console.log("up"); swfZ = true; } } //TRUE FULSCREEN MODE //SHIFT + CONTROL + F if (e.keyCode == 70 && e.shiftKey == true && (e.ctrlKey == true || e.metaKey == true)) { if(currentPageNumber == 0){ var w = screen.width; var h = screen.height; contHolder = ctr.innerHTML; if(window.innerHeight != document.getElementById("contraption").height){ oldH = document.getElementById("contraption").height; oldW = document.getElementById("contraption").width; checkHub = document.getElementById("sHubs").checked; checkLvl = document.getElementById("sLvl").checked; checkChat = document.getElementById("sChat").checked; checkScroll = document.getElementById("sScroll").checked; document.getElementById("contraption").style.position = "absolute"; document.getElementById("contraption").style.top = "0px"; document.getElementById("contraption").style.left = "0px"; document.getElementById("contraption").style.backgroundColor = "green"; document.getElementById("contraption").height = window.innerHeight; document.getElementById("contraption").width = window.innerWidth; document.getElementById("contraption").style.border = ""; document.getElementById('lateHub').style.display = 'none'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'none'; //document.getElementById('cInput').style.display = 'none'; //document.getElementById('ctitle').style.display = 'none'; //document.getElementById('cSubmit').style.display = 'none'; document.getElementById('resetHub').style.display = "none"; document.getElementById("randLevelHub").style.display = 'none'; document.getElementById("chatHub").style.display = 'none'; document.getElementById("leftBtn").style.display = 'none'; document.getElementById("rightBtn").style.display = 'none'; document.getElementById("pageDescription").style.display = 'none'; document.getElementById("settingsHub").style.display = 'none'; document.getElementById("sHub").style.display = 'none'; document.getElementById("fullScreenButton").style.display = 'none'; document.getElementById("tweakBtn").style.right = 45*scale+'px'; giveMessage("TRUE FULLSCREEN ACTIVATED"); trueFull = true; }else{ document.getElementById("contraption").height = oldH; document.getElementById("contraption").width = oldW; document.getElementById("settingsHub").style.display = 'block'; document.getElementById("fullScreenButton").style.display = 'block'; document.getElementById("tweakBtn").style.right = 315*scale+'px'; giveMessage("TRUE FULLSCREEN DEACTIVATED"); if(document.getElementById("sHubs").checked){ document.getElementById('lateHub').style.display = 'none'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'none'; //document.getElementById('cInput').style.display = 'none'; //document.getElementById('ctitle').style.display = 'none'; //document.getElementById('cSubmit').style.display = 'none'; document.getElementById('resetHub').style.display = "none"; }else{ document.getElementById('lateHub').style.display = 'block'; document.getElementById('TopHub').style.display = 'none'; document.getElementById('dsgHub').style.display = 'none'; //document.getElementById('cAmt').style.display = 'block'; //document.getElementById('cInput').style.display = 'block'; //document.getElementById('ctitle').style.display = 'block'; //document.getElementById('cSubmit').style.display = 'block'; document.getElementById('resetHub').style.display = "block"; } if(document.getElementById("sLvl").checked){ document.getElementById("randLevelHub").style.display = 'none'; }else{ document.getElementById("randLevelHub").style.display = 'block'; } if(document.getElementById("sChat").checked){ document.getElementById("chatHub").style.display = 'none'; }else{ document.getElementById("chatHub").style.display = 'block'; } if(document.getElementById("sScroll").checked){ document.getElementById("leftBtn").style.display = 'none'; document.getElementById("rightBtn").style.display = 'none'; document.getElementById("pageDescription").style.display = 'none'; }else{ document.getElementById("leftBtn").style.display = 'block'; document.getElementById("rightBtn").style.display = 'block'; document.getElementById("pageDescription").style.display = 'block'; } if(inFullScreen){ document.getElementById("contraption").style.position = "absolute"; document.getElementById("contraption").style.top = "45px"; document.getElementById("contraption").style.left = "calc(50% - "+540*scale+"px)"; document.getElementById("contraption").style.border = 10+scale+"px solid #2550FF"; document.getElementById("contraption").style.borderRadius = 25*scale+"px"; }else{ document.getElementById("contraption").style.position = "initial"; document.getElementById("contraption").style.top = "initial"; document.getElementById("contraption").style.left = "initial"; document.getElementById("contraption").style.border = "initial"; } trueFull = false; } }else{ giveMessage("Need to be on Game Page!"); } } } document.onkeydown = KeyPress; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////RED ARROW BLOCKER//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// var btnOff = ""; var btnOn = ""; var tweakBtn = document.createElement("input"); var btnState = "Off"; tweakBtn.type = "image"; tweakBtn.src = btnOff; tweakBtn.title = "Toggle Red Arrow Blocker"; tweakBtn.style.width = 2.5*scale+"em"; tweakBtn.id = "tweakBtn"; tweakBtn.style.cursor = "pointer"; tweakBtn.style.position = "absolute"; tweakBtn.style.top = "0px"; tweakBtn.style.right = 315*scale+"px"; centered.appendChild(tweakBtn); document.getElementById("tweakBtn").onclick = function(){ if(btnState == "Off"){ tweakBtn.src = btnOn; btnState = "On"; giveMessage("Red Arrow Blocker On"); document.getElementById('rArrow').style.display = "block"; }else{ tweakBtn.src = btnOff; btnState = "Off"; giveMessage("Red Arrow Blocker Off"); document.getElementById('rArrow').style.display = "none"; } }; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////NUMBER TO STAR FUNCTION////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function numToStar(number,id,type,rate){ var lvlId = id; var whichClass = type; var whichRate = rate; //console.log(which) var classOpt = ""; var rateOpt = ""; var backCol = ""; var starTitle = ""; var star = ""; var emptyStar = ""; var transStar = ""; var str = ""; if(whichClass == 'd'){ classOpt = "designRateClass"; }else{ classOpt = "levelRateClass"; } if(whichRate == 'Q'){ rateOpt = "Quality"; backCol = "#ff0000" starTitle = "Quality Rating"; }else{ rateOpt = "Difficulty"; backCol = "#00ff00"; starTitle = "Difficulty Rating"; } str += "<div style='width: 125px;'><div style='width: "+(number/5)*100+"%; background-color: "+backCol+"; height: 18px;'></div></div><div title='"+starTitle+": "+number+"' style='width: 125px; z-index: 5;position: relative; height: 15px;margin-top: -18px;'>"; for(var i = 0; i<5;i++){ str += "<img src='"+transStar+"' alt='ratingStar' id='"+rateOpt+""+lvlId+"star"+i+"' class='"+classOpt+"' >"; } str += "</div>"; /* for(var i = 0;i<round;i++){ str += "<img src='"+star+"' alt='ratingStar' id='"+rateOpt+""+lvlId+"star"+i+"' class='"+classOpt+"'>"; } for(var j = 0; j<empNum;j++){ str += "<img src='"+emptyStar+"' alt='ratingStar' id='"+rateOpt+""+lvlId+"star"+(j+round)+"' class='"+classOpt+"'>"; } */ return str; } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////STAR CLICK RATING//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function starRating(id,type){ var idToParse = id; //console.log(idToParse); var isQuality = idToParse.match("Quality"); var isDifficulty = idToParse.match("Difficulty"); var whichType = ""; //console.log(isQuality); //console.log(isDifficulty); var whichRate = ""; if(isQuality){ whichRate = "qualityRating"; whichType = "Quality"; } if(isDifficulty){ whichRate = "difficultyRating"; whichType = "Difficulty"; } //console.log(whichRate); var levelId = idToParse.split(whichType).pop(); levelId = levelId.split("star"); var howMany = levelId[1]; howMany++; levelId = levelId[0]; //console.log(levelId); //console.log(howMany); var rateType = ""; if(type == 'd'){ rateType = "designId"; }else{ rateType = "levelId"; } //console.log(rateType); $.ajax({ type: "POST", url: "http://fantasticcontraption.com/setRating.php", data: { xml: "<setRating><" +rateType+ ">" + levelId + "</" +rateType+ "><"+whichRate+">" + howMany + "</"+whichRate+"><userId>" + getCookie("userid") + "</userId></setRating>" } }); giveMessage(whichType+" has been rated: "+howMany+"!"); alert(whichType+" has been rated: "+howMany+"!\nPlease Refresh Hub To See Changes!"); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////CREATE THUMBNAILS//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function createCanvas(id,itr,hub){ var levelId = id; var itr = itr; var wHub; var cId; var cId = "img"+levelId+""; if(hub == "top"){ wHub = document.getElementById("TopInnerHub"); } else{ wHub = document.getElementById("lateInnerHub"); } $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/retrieveLevel.php", data: { id: levelId }, error: function() { console.log("Error on ajax for: "+levelId+"...skipping Id"); if(hub == "top"){ wHub.innerHTML += "<h4>Level ID: "+levelId+" skipped due to error</h4><br>"; topItr++ setTop(); }else{ wHub.innerHTML += "<h4>Level ID: "+levelId+" skipped due to error</h4><br>"; lateItr++ setLate(); } }, success: function(data) { //GET ALL THE ELEMENTS var sR = data.getElementsByTagName('StaticRectangle'); var sC = data.getElementsByTagName('StaticCircle'); var dR = data.getElementsByTagName('DynamicRectangle'); var dC = data.getElementsByTagName('DynamicCircle'); var bA = data.getElementsByTagName('start'); var gA = data.getElementsByTagName('end'); var uW = data.getElementsByTagName('NoSpinWheel'); var gR = data.getElementsByTagName('JointedDynamicRectangle'); var gC = []; var NongC = []; for (i = 0; i < uW.length; i++){ if(uW[i].getElementsByTagName('goalBlock')[0].innerHTML=='true'){ gC.push(uW[i]); }else{ NongC.push(uW[i]); } } var cW = data.getElementsByTagName('ClockwiseWheel'); var ccW = data.getElementsByTagName('CounterClockwiseWheel'); //Try and get the centers of a level var xx = data.getElementsByTagName('x'); var xNum = []; for(i = 0; i < xx.length; i++){ xNum[i] = xx[i].innerHTML; } var yy = data.getElementsByTagName('y'); var yNum = []; for(i = 0; i < yy.length; i++){ yNum[i] = yy[i].innerHTML; } var xMin = Math.min.apply(null, xNum); var xMax = Math.max.apply(null, xNum); var xCenter = (xMax + xMin)/2; var yMin = Math.min.apply(null, yNum); var yMax = Math.max.apply(null, yNum); var yCenter = (yMax + yMin)/2; //START TO CREATE CANVAS var defaultWidth = 1800; var defaultHeight = 1440; var scale = 1/6; var canvasWidth = defaultWidth * scale; var canvasHeight = defaultHeight * scale; wHub.innerHTML += '<canvas id="'+cId+'" width="'+canvasWidth+'" height="'+canvasHeight+'" style="border:1px solid #d3d3d3;"><br>'; var canvas = document.getElementById(cId); var centerX = (canvasWidth * 0.5); var centerY = (canvasHeight * 0.5); canvas.style.visibility = "hidden"; canvas.style.zIndex = "1000"; var ctx = canvas.getContext("2d"); ctx.strokeStyle = "#85AFF3"; ctx.strokeRect(0,0,900,720); ctx.fillStyle = "#85AFF3"; ctx.fillRect(0,0,900,720); for(i = 0; i < bA.length; i++){ var x = (bA[i].getElementsByTagName('x')[0].innerHTML); var y = (bA[i].getElementsByTagName('y')[0].innerHTML); x = x-xCenter; y = y-yCenter; var w = bA[i].getElementsByTagName('width')[0].innerHTML; var h = bA[i].getElementsByTagName('height')[0].innerHTML; var type = 1; drawObject(x*scale,y*scale,w*scale,h*scale,0,type); } for(i = 0; i < bA.length; i++){ var x = bA[i].getElementsByTagName('x')[0].innerHTML; var y = bA[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = bA[i].getElementsByTagName('width')[0].innerHTML; var h = bA[i].getElementsByTagName('height')[0].innerHTML; var type = 1; fillObject(x*scale,y*scale,w*scale,h*scale,0,type); } for(i = 0; i < gA.length; i++){ var x = gA[i].getElementsByTagName('x')[0].innerHTML; var y = gA[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = gA[i].getElementsByTagName('width')[0].innerHTML; var h = gA[i].getElementsByTagName('height')[0].innerHTML; var type = 2; drawObject(x*scale,y*scale,w*scale,h*scale,0,type); } for(i = 0; i < gA.length; i++){ var x = gA[i].getElementsByTagName('x')[0].innerHTML; var y = gA[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = gA[i].getElementsByTagName('width')[0].innerHTML; var h = gA[i].getElementsByTagName('height')[0].innerHTML; var type = 2; fillObject(x*scale,y*scale,w*scale,h*scale,0,type); } for(i = 0; i < sR.length; i++){ var x = sR[i].getElementsByTagName('x')[0].innerHTML; var y = sR[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = sR[i].getElementsByTagName('width')[0].innerHTML; var h = sR[i].getElementsByTagName('height')[0].innerHTML; var a = sR[i].getElementsByTagName('rotation')[0].innerHTML; var type = 3; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < sC.length; i++){ var x = sC[i].getElementsByTagName('x')[0].innerHTML; var y = sC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = sC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = sC[i].getElementsByTagName('height')[0].innerHTML; var a = sC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 4; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < dR.length; i++){ var x = dR[i].getElementsByTagName('x')[0].innerHTML; var y = dR[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = dR[i].getElementsByTagName('width')[0].innerHTML; var h = dR[i].getElementsByTagName('height')[0].innerHTML; var a = dR[i].getElementsByTagName('rotation')[0].innerHTML; var type = 5; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < dC.length; i++){ var x = dC[i].getElementsByTagName('x')[0].innerHTML; var y = dC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = dC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = dC[i].getElementsByTagName('height')[0].innerHTML; var a = dC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 6; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < gR.length; i++){ var x = gR[i].getElementsByTagName('x')[0].innerHTML; var y = gR[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = gR[i].getElementsByTagName('width')[0].innerHTML; var h = gR[i].getElementsByTagName('height')[0].innerHTML; var a = gR[i].getElementsByTagName('rotation')[0].innerHTML; var type = 7; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < gC.length; i++){ var x = gC[i].getElementsByTagName('x')[0].innerHTML; var y = gC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = gC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = gC[i].getElementsByTagName('height')[0].innerHTML; var a = gC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 8; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < NongC.length; i++){ var x = NongC[i].getElementsByTagName('x')[0].innerHTML; var y = NongC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = NongC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = NongC[i].getElementsByTagName('height')[0].innerHTML; var a = NongC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 9; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < cW.length; i++){ var x = cW[i].getElementsByTagName('x')[0].innerHTML; var y = cW[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = cW[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = cW[i].getElementsByTagName('height')[0].innerHTML; var a = cW[i].getElementsByTagName('rotation')[0].innerHTML; var type = 10; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < ccW.length; i++){ var x = ccW[i].getElementsByTagName('x')[0].innerHTML; var y = ccW[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = ccW[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = ccW[i].getElementsByTagName('height')[0].innerHTML; var a = ccW[i].getElementsByTagName('rotation')[0].innerHTML; var type = 11; drawObject(x*scale,y*scale,w*scale,h*scale,a,type); } //Start Filling Objects for(i = 0; i < sR.length; i++){ var x = sR[i].getElementsByTagName('x')[0].innerHTML; var y = sR[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = sR[i].getElementsByTagName('width')[0].innerHTML; var h = sR[i].getElementsByTagName('height')[0].innerHTML; var a = sR[i].getElementsByTagName('rotation')[0].innerHTML; var type = 3; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < sC.length; i++){ var x = sC[i].getElementsByTagName('x')[0].innerHTML; var y = sC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = sC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = sC[i].getElementsByTagName('height')[0].innerHTML; var a = sC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 4; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < dR.length; i++){ var x = dR[i].getElementsByTagName('x')[0].innerHTML; var y = dR[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = dR[i].getElementsByTagName('width')[0].innerHTML; var h = dR[i].getElementsByTagName('height')[0].innerHTML; var a = dR[i].getElementsByTagName('rotation')[0].innerHTML; var type = 5; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < dC.length; i++){ var x = dC[i].getElementsByTagName('x')[0].innerHTML; var y = dC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = dC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = dC[i].getElementsByTagName('height')[0].innerHTML; var a = dC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 6; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < gR.length; i++){ var x = gR[i].getElementsByTagName('x')[0].innerHTML; var y = gR[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = gR[i].getElementsByTagName('width')[0].innerHTML; var h = gR[i].getElementsByTagName('height')[0].innerHTML; var a = gR[i].getElementsByTagName('rotation')[0].innerHTML; var type = 7; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < gC.length; i++){ var x = gC[i].getElementsByTagName('x')[0].innerHTML; var y = gC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = gC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = gC[i].getElementsByTagName('height')[0].innerHTML; var a = gC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 8; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < NongC.length; i++){ var x = NongC[i].getElementsByTagName('x')[0].innerHTML; var y = NongC[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = NongC[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = NongC[i].getElementsByTagName('height')[0].innerHTML; var a = NongC[i].getElementsByTagName('rotation')[0].innerHTML; var type = 9; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < cW.length; i++){ var x = cW[i].getElementsByTagName('x')[0].innerHTML; var y = cW[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = cW[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = cW[i].getElementsByTagName('height')[0].innerHTML; var a = cW[i].getElementsByTagName('rotation')[0].innerHTML; var type = 10; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } for(i = 0; i < ccW.length; i++){ var x = ccW[i].getElementsByTagName('x')[0].innerHTML; var y = ccW[i].getElementsByTagName('y')[0].innerHTML; x = x-xCenter; y = y-yCenter; var w = ccW[i].getElementsByTagName('width')[0].innerHTML; if(w < 8){ w = 8.001; } var h = ccW[i].getElementsByTagName('height')[0].innerHTML; var a = ccW[i].getElementsByTagName('rotation')[0].innerHTML; var type = 11; fillObject(x*scale,y*scale,w*scale,h*scale,a,type); } //Convert Canvas to Image var dataURL = canvas.toDataURL(); wHub.removeChild(canvas); //Top Hub if (hub == "top"){ wHub.innerHTML += "<img src='"+dataURL+"' alt='' border='1' width='95%' style='display:inline;vertical-align: middle'></img><br>"; wHub.innerHTML += "<table style='font-size:12px;table-layout: fixed;'><tr><td align='left' width='123px'><strong>" + (itr + 1) + ") </strong></font>" + topLvlListName[itr] + " </td></tr><tr><td align='left'><strong>Author: </strong>" + topLvlListA[itr] + "</td></tr><tr><td align='left'><strong>Description: </strong>" + topLvlListDesc[itr] + "</td></tr><tr><td align='left'>" + numToStar(topLvlListQ[itr],topLvlListId[itr],'l','Q') + "</td></tr><tr><td align='left'>" + numToStar(topLvlListD[itr],topLvlListId[itr],'l','D') + "</td></tr></table>"; //Create Load Button var genButtonLoad = document.createElement("input"); genButtonLoad.type = "image"; genButtonLoad.src = lBtn; genButtonLoad.style.verticalAlign = "middle"; genButtonLoad.style.padding = "1px"; genButtonLoad.id = topLvlListId[itr]; genButtonLoad.title = "Play Level"; genButtonLoad.setAttribute("class", "loadClass"); wHub.appendChild(genButtonLoad); //Add space between buttons wHub.innerHTML += " "; //Create Design Button var genButtonDesign = document.createElement("input"); genButtonDesign.type = "image"; genButtonDesign.title = "See Designs"; genButtonDesign.src = dBtn; genButtonDesign.width = "30"; genButtonDesign.height = "30"; genButtonDesign.style.verticalAlign = "middle"; genButtonDesign.style.padding = "1px"; genButtonDesign.id = "designId="+topLvlListId[itr]; genButtonDesign.setAttribute("class", "designClass"); wHub.appendChild(genButtonDesign); wHub.innerHTML += "<hr><br>"; topItr++ setTop(); }else{ wHub.innerHTML += "<img src='"+dataURL+"' alt='' border='1' width='95%' style='display:inline;vertical-align: middle'></img><br>"; wHub.innerHTML += "<table style='font-size:12px;'><tr><td align='left' width='123px'><strong>" + (itr + 1) + ") </strong></font>" + lateLvlListName[itr] + " </td></tr><tr><td align='left'><strong>Author: </strong>" + lateLvlListA[itr] + "</td></tr><tr><td align='left'><strong>Description: </strong>" + lateLvlListDesc[itr] + "</td></tr><tr><td align='left'>" + numToStar(lateLvlListQ[itr],lateLvlListId[itr],'l','Q') + "</td></tr><tr><td align='left' >" + numToStar(lateLvlListD[itr],lateLvlListId[itr],'l','D') + "</td></tr></table>"; //Create Load Button var genButtonLoad = document.createElement("input"); genButtonLoad.type = "image"; genButtonLoad.src = "http://i66.tinypic.com/9kzatg.png"; genButtonLoad.style.verticalAlign = "left"; genButtonLoad.title = "Play Level"; genButtonLoad.style.padding = "1px"; genButtonLoad.id = lateLvlListId[itr]; genButtonLoad.setAttribute("class", "loadClass"); wHub.appendChild(genButtonLoad); //Add space between buttons wHub.innerHTML += " "; //Create Design Button var genButtonDesign = document.createElement("input"); genButtonDesign.type = "image"; genButtonDesign.title = "See Designs"; genButtonDesign.src = "http://i68.tinypic.com/eleiv7.png"; genButtonDesign.width = "30"; genButtonDesign.height = "30"; genButtonDesign.style.verticalAlign = "left"; genButtonDesign.style.padding = "1px"; genButtonDesign.id = "designId="+lateLvlListId[itr]; genButtonDesign.setAttribute("class", "designClass"); wHub.appendChild(genButtonDesign); wHub.innerHTML += "<hr><br>"; lateItr++ setLate(); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////DRAW THUMBNAIL OBJECTS/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //Start Awesome Functions Created by Zhyrek to draw canvas function drawObject(x, y, w, h, a, type) { w -= 8 * scale; h -= 8 * scale; var ca = Math.cos(a); var sa = Math.sin(a); ctx.transform(1,0,0,1,x+centerX,y+centerY); ctx.transform(ca,sa,-sa,ca,0,0); ctx.lineJoin="round"; ctx.lineWidth = 4 * scale; if(type == 1)//buildArea { ctx.strokeStyle = "#7F66ED"; ctx.strokeRect(-w/2,-h/2,w,h); } else if(type == 2)//goalArea { ctx.strokeStyle = "#B46268"; ctx.strokeRect(-w/2,-h/2,w,h); } else if(type == 3)//staticRect { ctx.strokeStyle = "#1D8501"; ctx.strokeRect(-w/2,-h/2,w,h); } else if(type == 4)//staticCircle { ctx.strokeStyle = "#1D8501"; ctx.arc(0,0,w,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } else if(type == 5)//dynamicRect { ctx.strokeStyle = "#BD5420"; ctx.strokeRect(-w/2,-h/2,w,h); } else if(type == 6)//dynamicCircle { ctx.strokeStyle = "#BD5420"; ctx.arc(0,0,w,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } else if(type == 7)//goalRect { ctx.strokeStyle = "#BD5420"; ctx.strokeRect(-w/2,-h/2,w,h); } else if(type == 8)//goalCircle { ctx.strokeStyle = "#B46268"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } else if(type == 9)//blueWheel { ctx.strokeStyle = "#4452FC"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } else if(type == 10)//yellowWheel { ctx.strokeStyle = "#F37E22"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } else if(type == 11)//pinkWheel { ctx.strokeStyle = "#CB2EA5"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } ctx.setTransform(1,0,0,1,0,0); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////FILL THUMBNAIL OBJECTS/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function fillObject(x, y, w, h, a, type) { w -= 8 * scale; h -= 8 * scale; var ca = Math.cos(a); var sa = Math.sin(a); ctx.transform(1,0,0,1,x+centerX,y+centerY); ctx.transform(ca,sa,-sa,ca,0,0); ctx.lineJoin="round"; ctx.lineWidth = 4 * scale; if(type == 1)//buildArea { ctx.fillStyle = "#BFD8F8"; ctx.fillRect(-w/2,-h/2,w,h); } else if(type == 2)//goalArea { ctx.fillStyle = "#EA8C92"; ctx.fillRect(-w/2,-h/2,w,h); } else if(type == 3)//staticRect { ctx.fillStyle = "#2BC500"; ctx.fillRect(-w/2,-h/2,w,h); } else if(type == 4)//staticCircle { ctx.fillStyle = "#2BC500"; ctx.arc(0,0,w,0,Math.PI*2); ctx.fill(); ctx.beginPath(); } else if(type == 5)//dynamicRect { ctx.fillStyle = "#F2DF37"; ctx.fillRect(-w/2,-h/2,w,h); } else if(type == 6)//dynamicCircle { ctx.fillStyle = "#F0873A"; ctx.arc(0,0,w,0,Math.PI*2); ctx.fill(); ctx.beginPath(); } else if(type == 7)//goalRect { ctx.fillStyle = "#F65D6A"; ctx.fillRect(-w/2,-h/2,w,h); ctx.lineWidth = 2 * scale; ctx.strokeStyle = "#828282"; ctx.arc(0,0,1.5,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(w/2,h/2,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(w/2,-h/2,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(-w/2,-h/2,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(-w/2,h/2,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } else if(type == 8)//goalCircle { ctx.fillStyle = "#F65D6A"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.fill(); ctx.beginPath(); } else if(type == 9)//blueWheel { ctx.fillStyle = "#94FEE1"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.fill(); ctx.beginPath(); } else if(type == 10)//yellowWheel { ctx.fillStyle = "#F9F316"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.fill(); ctx.beginPath(); } else if(type == 11)//pinkWheel { ctx.fillStyle = "#FBC9CC"; ctx.arc(0,0,w/2,0,Math.PI*2); ctx.fill(); ctx.beginPath(); } if(type > 7) { w += 4; h += 4; ctx.lineWidth = 2 * scale; ctx.strokeStyle = "#828282"; ctx.arc(0,h*scale,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(w*scale,0,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(0,-h*scale,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.arc(-w*scale,0,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); ctx.strokeStyle = "#FFFFFF"; ctx.arc(0,0,3*scale,0,Math.PI*2); ctx.stroke(); ctx.beginPath(); } ctx.setTransform(1,0,0,1,0,0); } } }); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////RESET THE HUB//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function resetHub(){ lateInnerHub.innerHTML = ""; lateTopHub.innerHTML = ""; reset.style.display = "none"; //ctitle.style.display = "none"; //cSubmit.style.display = "none"; //cInput.style.display = "none"; getTop(); getLatest(); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////GET TOP LEVELS/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getTop(){ $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/getUserGenLevels.php", data: { limitCount: maxL }, success: function(data) { var str = new XMLSerializer().serializeToString(data); topLvlList = str.match(/<level>[\s\S]*?<\/level>/gm); //console.log(topLvlList); if(topLvlList){ for(var i = 0; i < topLvlList.length; i++){ topLvlListId[i] = topLvlList[i].match(/levelId>.+?(?=<)/g); topLvlListId[i] = topLvlListId[i][0].split(">").pop(); //console.log("Level ID: " + topLvlListId[i]); topLvlListName[i] = topLvlList[i].match(/levelName>.+?(?=<)/g); topLvlListName[i] = topLvlListName[i][0].split(">").pop(); //console.log("Level Name: " + topLvlListName[i]); topLvlListA[i] = topLvlList[i].match(/userName>.+?(?=<)/g); if(topLvlListA[i]){ topLvlListA[i] = topLvlListA[i][0].split(">").pop(); }else{ topLvlListA[i] = " "; } //console.log("Level Author: " + topLvlListA[i]); topLvlListDesc[i] = topLvlList[i].match(/description>.+?(?=<)/g); if(topLvlListDesc[i]){ topLvlListDesc[i] = topLvlListDesc[i][0].split(">").pop(); }else{ topLvlListDesc[i] = " "; } //console.log("Level Description: " + topLvlListDesc[i]); topLvlListQ[i] = topLvlList[i].match(/quality>.+?(?=<)/g); if(topLvlListQ[i]){ topLvlListQ[i] = topLvlListQ[i][0].split(">").pop(); }else{ topLvlListQ[i] = "N/A"; } //console.log("Level Quality: " + topLvlListQ[i]); topLvlListD[i] = topLvlList[i].match(/difficulty>.+?(?=<)/g); if(topLvlListD[i]){ topLvlListD[i] = topLvlListD[i][0].split(">").pop(); }else{ topLvlListD[i] = "N/A"; } //console.log("Level Difficulty: " + topLvlListD[i]); } } setTop(); } }); } getTop(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////TOP HUB THUMBNAIL//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function setTop(){ var lateTopHub = document.getElementById('TopInnerHub'); if(topItr < maxL){ createCanvas(topLvlListId[topItr], topItr, "top"); }else{ hubsLoaded(); } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////GET LATEST LEVELS//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getLatest(){ $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/getUserGenLevels.php", data: { limitCount: maxL, orderBy: "date" }, success: function(data) { var str = new XMLSerializer().serializeToString(data); lateLvlList = str.match(/<level>[\s\S]*?<\/level>/gm); //console.log(lateLvlList); if(lateLvlList){ for(var i = 0; i < lateLvlList.length; i++){ lateLvlListId[i] = lateLvlList[i].match(/levelId>.+?(?=<)/g); lateLvlListId[i] = lateLvlListId[i][0].split(">").pop(); //console.log("Level ID: " + lateLvlListId[i]); lateLvlListName[i] = lateLvlList[i].match(/levelName>.+?(?=<)/g); lateLvlListName[i] = lateLvlListName[i][0].split(">").pop(); //console.log("Level Name: " + lateLvlListName[i]); lateLvlListA[i] = lateLvlList[i].match(/userName>.+?(?=<)/g); if(lateLvlListA[i]){ lateLvlListA[i] = lateLvlListA[i][0].split(">").pop(); }else{ lateLvlListA[i] = " "; } //console.log("Level Author: " + lateLvlListA[i]); lateLvlListDesc[i] = lateLvlList[i].match(/description>.+?(?=<)/g); if(lateLvlListDesc[i]){ lateLvlListDesc[i] = lateLvlListDesc[i][0].split(">").pop(); }else{ lateLvlListDesc[i] = " "; } //console.log("Level Description: " + lateLvlListDesc[i]); lateLvlListQ[i] = lateLvlList[i].match(/quality>.+?(?=<)/g); if(lateLvlListQ[i]){ lateLvlListQ[i] = lateLvlListQ[i][0].split(">").pop(); }else{ lateLvlListQ[i] = "N/A"; } //console.log("Level Quality: " + lateLvlListQ[i]); lateLvlListD[i] = lateLvlList[i].match(/difficulty>.+?(?=<)/g); if(lateLvlListD[i]){ lateLvlListD[i] = lateLvlListD[i][0].split(">").pop(); }else{ lateLvlListD[i] = "N/A"; } //console.log("Level Difficulty: " + lateLvlListD[i]); } } setLate(); } }); } getLatest(); //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////LATEST HUB THUMBNAIL///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function setLate(){ var lateInnerHub = document.getElementById('lateInnerHub'); if(lateItr < maxL){ createCanvas(lateLvlListId[lateItr], lateItr, "late"); }else{ hubsLoaded(); } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////GET DESIGNS////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// function getDsg(id){ var levelId = id.split("=").pop(); dsgId = []; dsgName = []; dsgUser = []; var dsgDesc = []; var dsgQ = []; var dsgList = []; dsgInnerHub.innerHTML = ""; $.ajax({ type: "POST", dataType: "xml", url: "http://fantasticcontraption.com/getUserDesigns.php", data: { levelId: levelId, onlyPublished: 1, userId: 1672546, limitOffset: 0, limitCount: 2000000000 }, success: function(data) { var str = new XMLSerializer().serializeToString(data); //console.log(str); dsgList = str.match(/<design>[\s\S]*?<\/design>/gm); //console.log(dsgList); if(dsgList){ document.getElementById('dsgHub').style.display = 'block'; document.getElementById('lateHub').style.display = 'none'; document.getElementById('TopHub').style.display = 'none'; for (i = 0; i < dsgList.length; i++){ dsgId[i] = dsgList[i].match(/designId>.+?(?=<)/g); dsgId[i] = dsgId[i][0].split(">").pop(); //console.log(dsgId[i]); dsgName[i] = dsgList[i].match(/name>.+?(?=<)/g); if(dsgName[i]){ dsgName[i] = dsgName[i][0].split(">").pop(); }else{ dsgName[i] = " "; } //console.log(dsgName[i]); dsgUser[i] = dsgList[i].match(/userName>.+?(?=<)/g); dsgUser[i] = dsgUser[i][0].split(">").pop(); //console.log(dsgUser[i]); dsgDesc[i] = dsgList[i].match(/description>.+?(?=<)/g); if(dsgDesc[i]){ dsgDesc[i] = dsgDesc[i][0].split(">").pop(); }else{ dsgDesc[i] = " "; } //console.log(dsgDesc[i]); dsgQ[i] = dsgList[i].match(/quality>.+?(?=<)/g); dsgQ[i] = dsgQ[i][0].split(">").pop(); //dsgInnerHub.innerHTML += "<span style='text-align: left;'><table><tr><td><strong><font size='3'><left>Name: </strong></font></td><td>" + dsgName[i] + "</td></tr><tr><td><strong><font size='3'>Author: </strong></font></td><td>"+ dsgUser[i] +"</td></tr><tr><td><strong><font size='3'>Description: </strong></font></td><td>"+ dsgDesc[i] +"</td></tr><tr><td><strong><font size='3'>Quality: </strong></font></td><td>"+ numToStar(dsgQ[i]) +"</td></tr></table></strong></font></left></span>"; dsgInnerHub.innerHTML += "<table style='font-size:12px;'><tr><td width='125px'><strong>Name: </strong>" + dsgName[i] + " </td></tr><tr><td align='left'><strong>Author: </strong>" + dsgUser[i] + "</td></tr><tr><td align='left'><strong>Description: </strong>" + dsgDesc[i] + "</td></tr><tr><td align='left'>" + numToStar(dsgQ[i],dsgId[i],'d',"Q") + "</td></tr></table>"; var genButtonDesign = document.createElement("input"); genButtonDesign.type = "image"; genButtonDesign.src = "http://i66.tinypic.com/9kzatg.png"; genButtonDesign.title = "Load Design"; genButtonDesign.style.padding = "3px"; genButtonDesign.id = dsgId[i]; genButtonDesign.setAttribute("class", "designLoad"); dsgInnerHub.appendChild(genButtonDesign); dsgInnerHub.innerHTML += "<br /><hr><br>"; } }else{ alert("There are no designs for this level."); } } }); } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////LEVEL/DESIGN LOADING BUTTONS////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// document.onclick=function(event){ if(event.target.getAttribute("class") == "loadClass"){ loadLvl(event.target.id); } else if(event.target.getAttribute("class") == "designClass"){ getDsg(event.target.id); } else if(event.target.getAttribute("class") == "designLoad"){ setDsg(event.target.id); } else if(event.target.getAttribute("class") == "designRateClass"){ starRating(event.target.id,'d'); } else if(event.target.getAttribute("class") == "levelRateClass"){ starRating(event.target.id,'l'); } }; function setDsg(id){ if (pageLocked) { giveMessage("You cannot do that while the page is locked."); } else { var h = document.getElementById("contraption").height; var w = document.getElementById("contraption").width; document.getElementById("maincontent").innerHTML = '<embed type="application/x-shockwave-flash" src="/game/Contraption.swf" width="'+w+'" height="'+h+'" id="contraption" name="contraption" quality="high" allowfullscreen="true" allowscriptaccess="always" flashvars="designId=' + id + '&wMode=true" swliveconnect="true">'; setTimeout(function(){ document.elementFromPoint(10*scale, 10*scale).click(); }, 1); document.elementFromPoint(10*scale, 10*scale).click(); contraption=getFlash(); getUseFlashVars(); } } function loadLvl(id){ if (pageLocked) { giveMessage("You cannot do that while the page is locked."); } else { var h = document.getElementById("contraption").height; var w = document.getElementById("contraption").width; document.getElementById("maincontent").innerHTML = '<embed type="application/x-shockwave-flash" src="/game/Contraption.swf" width="'+w+'" height="'+h+'" id="contraption" name="contraption" quality="high" allowfullscreen="true" allowscriptaccess="always" flashvars="levelId=' + id + '&wMode=true" swliveconnect="true">'; setTimeout(function(){ document.elementFromPoint(10, 10).click(); }, 1); document.elementFromPoint(10, 10).click(); contraption = getFlash(); getUseFlashVars(); } } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ///////////////MESSAGE BOX////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// //Create a way of showing messages //Let's reserve the bottom left corner for messages function setupMessageSpace() { var messageSpace = document.createElement('div'); with (messageSpace) { id = "msg"; style.position = "absolute"; style.right = 40*scale+"px"; style.bottom = 8*scale+"px"; style.fontSize = 1.5*scale+"em"; } document.body.appendChild(messageSpace); } setupMessageSpace(); //Now the function to display a message! function giveMessage(message) { var msgSpace = document.getElementById('msg'); msgSpace.innerHTML = message; //Now fade out the message clearTimeout(messageTimeout); //First clear the old one if we are overriting it messageTimeout = setTimeout(fadeText, "2000"); function fadeText() {$(msgSpace).stop(true, true).fadeOut( "slow", function() {msgSpace.innerHTML = ""; msgSpace.style.display = 'initial';} );} } //Setup the SWF to interact with javascript contraption.setAttribute("swliveconnect", true); //Don't think this actually does anything, but alas //})(); } //End try catch(err) { alert("It looks like an error occured:\n> " + err.message + "\nIf you would like, please let marjo know."); }