Файловый менеджер - Редактировать - /home/jogoso94/public_html/static/img/logo/gameapi.tar
�азад
v1.js 0000644 00000153376 15043717150 0005452 0 ustar 00 var api; if (typeof window !== "undefined" && !window.famobi) { ! function(a, b) { var famobi = { orientationChangeCallback: null, brandingLogo: null, config: null, reached_home: false, splashComplete: false, init: function() { return new Promise(function(resolve, reject) { // famobi.json if(!this.config) { readTextFile("famobi.json", function(text){ var data = JSON.parse(text); if(!data.game_i18n) { console.error("famobi.json: field name 'game_i18n' is missing. For more information please visit: https://sites.google.com/a/famobi.com/api-docs/api-implementation/localization"); return; } this.config = data; if(this.config.disable_console) { window.console = { log: function() {}, warn: function() {}, info: function() {}, error: function() {} }; } this.log("init..."); this.game.init(); this.includeCSS("html5games/gameapi/v1/play.css"); // include css files for(var i = 0; this.config.includeCSS && i < this.config.includeCSS.length; i++) { this.includeCSS(this.config.includeCSS[i]); } window.famobi_gameJS.unshift("custom.js"); window.famobi_gameJS.unshift("html5games/gameapi/famobi_analytics_v1.js"); window.famobi_gameJS.unshift("html5games/gameapi/detection.js"); window.famobi_gameJS.unshift("html5games/gameapi/zepto.min.js"); // js files for(var i = 0; this.config.includeJS && i < this.config.includeJS.length; i++) { window.famobi_gameJS.unshift(this.config.includeJS[i]); } // orientation change window.addEventListener("orientationchange", function() { if (typeof this.orientationChangeCallback == "function") { this.orientationChangeCallback(); } }.bind(this), false); // aid var aid = this.getUrlParams()["fg_aid"]; window.famobi_multiplayer = this.config.features.multiplayer || false; this.config.gameParams = this.config.gameParams || {}; window.addEventListener("famobi_tracking_screen",(e)=>{ if(this.config.autoShowMenuScreens && this.config.autoShowMenuScreens.includes(e.detail.screen)) { this.reached_home = true; setTimeout(()=>{ //<< DIRTY FIX if(this.splashComplete)window.famobi.menu.show();},1000); //Menu wouldn't reopen because of some timing issue where it was immediatellzy closed after this command ran, so now the call is delayed by 1 second - performance wise not the best option } }) if(this.config.show_splash)this.showSplashScreen(()=>{ this.splashComplete = true; if(this.reached_home)window.famobi.menu.show(); }); var getGameTitle = function() { String.prototype.replaceAll = function(search, replacement) { var target = this; return target.split(search).join(replacement); }; function toTitleCase(str) { return str.replace(/\w\S*/g, function(txt){ return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase(); }); } return toTitleCase(window.famobi_gameID.replaceAll("-", " ")); }; document.title = this.config.title || getGameTitle(); // ads this.config.ads = this.config.ads || {}; resolve((window.famobi_gameID === "running-jack") ? false : true); }.bind(this)); } function readTextFile(file, callback) { var rawFile = new XMLHttpRequest(); rawFile.overrideMimeType("application/json"); rawFile.open("GET", file, true); rawFile.onreadystatechange = function() { if (rawFile.readyState === 4 && rawFile.status == "200") { callback(rawFile.responseText); } }; rawFile.send(null); } }.bind(this)); }, showInterstitialAd: function(force) { var _this = this; return new Promise(function(resolve, reject) { _this.showAd(function() { resolve(); }, force); }); }, forceAd: function(callback) { this.showAd(callback, true); }, rewardedAd: function(callback) { if (typeof callback == "function") { callback(); } }, showAd: function(callback, force) { if(!!this.config.ads.off) { this.log("ads: off"); if (typeof callback == "function") { callback(); } return; } this.log("showing ad..."); this.game.pause(); Promise.all([]).then(function(){ this.log("ad finished"); if (typeof callback == "function") { callback(); } setTimeout(function() { this.game.resume(); }.bind(this), 100); }.bind(this), function(){ this.log("ad finished"); if (typeof callback == "function") { callback(); } setTimeout(function() { this.game.resume(); }.bind(this), 100); }.bind(this)); }, ads: { adcount: 0, lastAdCall: null, hasCooledDown: function() { var self = window.famobi; var min_s_between = this.adcount === 0 && +self.config.ads.min_s_before > 0 ? +self.config.ads.min_s_before : +self.config.ads.min_s_between; var ret = self.now() - min_s_between * 1000 > M.lastAdCall; return ret; } }, // Localization gametranslation: { init: function() { window.famobi.gametranslation.curLangString = window.famobi.gametranslation.getUserLang(); // Always fall back to 'en' when the user locale is not supported or translated if (window.famobi.gametranslation.getSupportedLanguages().indexOf(window.famobi.gametranslation.curLangString) === -1) { window.famobi.gametranslation.curLangString = "en"; } window.famobi.gametranslation.translationData = window.famobi.gametranslation.getGameTranslations(); window.famobi.gametranslation.translateHtml(faZepto("body")); }, getSupportedLanguages: function() { return window.famobi.config.languages || Object.keys(window.famobi.config.game_i18n) || []; }, getGameTranslations: function() { var i18n = window.famobi.config.game_i18n, lang = window.famobi.gametranslation.curLangString; if (i18n.current) { return i18n.current; } faZepto.each(i18n, function(language, translations) { faZepto.each(translations, function(key, value) { if (value == null) { i18n[language][key] = ""; } else if (typeof i18n[language][key] === "string") { i18n[language][key] = value.replace(/\{lang\}/g, language); } }); }); i18n.current = faZepto.extend( {}, i18n["default"], i18n[window.famobi.config.aid + ".default"], i18n[lang], i18n[window.famobi.config.aid + "." + lang] ); return (window.famobi.config.game_i18n.current = i18n.current); }, translateString: function(key) { return window.famobi.gametranslation.translationData.hasOwnProperty(key) ? window.famobi.gametranslation.translationData[key] : null; }, getNavigatorLocale: function() { var language = ""; if (navigator.languages && window.famobi.sizeOf(navigator.languages)) { language = navigator.languages[0]; } else if (navigator.language) { language = navigator.language; } else if (navigator.userLanguage) { language = navigator.userLanguage; } else if (navigator.browserLanguage) { language = navigator.browserLanguage; } return language; }, getNavigatorLanguage: function() { return window.famobi.gametranslation.getNavigatorLocale().substr(0, 2); }, getUserLang: function() { var urlParams = window.famobi.getUrlParams(), lang = window.famobi.gametranslation.getNavigatorLanguage(); if (urlParams.locale && urlParams.locale.length == 2) { return urlParams.locale; } switch (lang) { case "ch": case "at": return "de"; default: return lang; } }, translateHtml: function($selector) { $selector.find("[data-i18n]").each(function() { var textkey = this.getAttribute("data-i18n"); this.innerHTML = window.famobi.gametranslation.translateString(textkey); }); return $selector; } }, __: function(key) { switch(key) { case "test_preload_image": return "html5games/images/testPreloadImage.png"; case "preload_image": return "html5games/images/" + (this.config.preload_image || "preloadImage") + ".png"; case "more_games_image": return this.getBrandingButtonImage(); default: // do nothing } var lang = this.getCurrentLanguage(); if(this.config.game_i18n) { if(this.config.game_i18n[lang]) { this.config.game_i18n[lang] = Object.assign(this.config.game_i18n[lang], this.config.game_i18n[this.config.aid+"."+lang]); } if(this.config.game_i18n[lang] && this.config.game_i18n[lang][key]) { if(typeof this.config.game_i18n[lang][key] === "string") { return this.config.game_i18n[lang][key].replace("{lang}", lang); } return this.config.game_i18n[lang][key]; } if(this.config.game_i18n.default) { this.config.game_i18n.default = Object.assign(this.config.game_i18n.default, this.config.game_i18n[this.config.aid+".default"]); } if(this.config.game_i18n.default && this.config.game_i18n.default[key]) { if(typeof this.config.game_i18n.default[key] === "string") { return this.config.game_i18n.default[key].replace("{lang}", lang); } return this.config.game_i18n.default[key]; } } this.warn("No translation found for '" + key + "'"); return null; }, getCurrentLanguage: function() { var locale; try{ locale = new URL(window.location.href).searchParams.get("locale") ; } catch(e) { console.error(e); } return locale || (navigator.language || navigator.userLanguage).substr(0, 2); }, showSplashScreen: function(pCallback, pShowTill_EVENT, pModal) { if(!document.getElementById("famobi_splash")) { //Splash Screen doesn't exist yet - Creating new Splash Screen from files in html5games/splash function readSplashFile(file, callback) { var rawFile = new XMLHttpRequest(); rawFile.overrideMimeType("application/xhtml+xml"); rawFile.open("GET", file, true); rawFile.onreadystatechange = function() { if (rawFile.readyState === 4 && rawFile.status == "200") { callback(rawFile.responseText); } }; rawFile.send(null); } readSplashFile("html5games/splash/splash.html",(response)=>{ this.includeCSS("html5games/splash/splash.css"); let splashScreen = document.createElement("div"); splashScreen.classList.add("splash-screen"); splashScreen.style.position = "absolute"; splashScreen.style.top = "0"; splashScreen.style.left = "0"; splashScreen.style.width = "100%"; splashScreen.style.height = "100%"; splashScreen.innerHTML = response; if(this.config.preload_image)splashScreen.querySelector(".logo").src = "html5games/images/"+this.config.preload_image+".png"; document.body.appendChild(splashScreen); this.splashScreen = splashScreen; if(pModal) return; //Show Modal does not define a closing condition and will keep the splash visible untill hideSplash is called manually if(!pShowTill_EVENT) { setTimeout(()=>this.hideSplashScreen(pCallback),this.config.splash_duration); } else { window.addEventListener(pShowTill_EVENT,()=>this.hideSplashScreen(pCallback)); } }); } else { //Splash Screen already exists, just need to reenable it. splashScreen.style.display = "block"; splashScreen.style.animation = splashScreen._orgAni; if(pModal) return; //Show Modal does not define a closing condition and will keep the splash visible untill hideSplash is called manually if(!pShowTill_EVENT) { setTimeout(()=>this.hideSplashScreen(pCallback),this.config.splash_duration); } else { window.removeEventListener(pShowTill_EVENT,()=>this.hideSplashScreen(pCallback)); window.addEventListener(pShowTill_EVENT,()=>this.hideSplashScreen(pCallback)); } } }, hideSplashScreen: function(pCallback) { this.splashScreen.style.display = "none"; if(!this.splashScreen._orgAni)this.splashScreen._orgAni = this.splashScreen.style.animation; //This saves the original animation - this is required to be able to rerun the animation the next time the splash is shown this.splashScreen.style.animation = "none"; if(pCallback)pCallback(this.splashScreen); }, getAbsolutePath: function(relativePath) { var absolutePath = document.location.protocol + "//" + document.location.pathname; // this method is only used for compatibility with Loaders in Cordova Apps, // otherwise absolute URIs with https://games.cdn.famobi.com are used if (document.location.protocol !== "file:") { return relativePath; } if (relativePath.startsWith("/")) { relativePath = relativePath.substr(1); } return ( absolutePath.substr(0, absolutePath.lastIndexOf("/") + 1) + relativePath ); }, menu: { create: function() { window.famobi.menu = this; window.famobi.menu.rootElement = document.getElementById("fg-root"); window.famobi.menu.bodyElement = document.getElementsByTagName("body")[0]; window.famobi.menu.headElement = document.getElementsByTagName("head")[0]; if (!window.famobi.menu.rootElement) { window.famobi.menu.rootElement = document.createElement("div"); window.famobi.menu.rootElement.setAttribute("id", "fg-root"); window.famobi.menu.rootElement.classList.add("fg_root"); window.famobi.menu.rootElement.style = "color: #999;font-weight:normal;"; document.body.insertBefore(window.famobi.menu.rootElement, document.body.firstChild); } // overlay window.famobi.menu.fgOverlay = document.createElement("div"); window.famobi.menu.fgOverlay.setAttribute("id","fg-overlay"); if (window.famobi.config.overlay_position) window.famobi.menu.fgOverlay.className = "overlay-" + window.famobi.config.overlay_position + " clip-" + window.famobi.config.overlay_position; if ( window.famobi.config.overlay_distance && window.famobi.config.overlay_distance !== "" ) { if ( window.famobi.config.overlay_position && window.famobi.config.overlay_position == "bottom" ) window.famobi.menu.fgOverlay.style.bottom = isNaN( window.famobi.config.overlay_distance ) ? window.famobi.config.overlay_distance : window.famobi.config.overlay_distance + "px"; else window.famobi.menu.fgOverlay.style.top = isNaN( window.famobi.config.overlay_distance ) ? window.famobi.config.overlay_distance : window.famobi.config.overlay_distance + "px"; } window.famobi.menu.rootElement.appendChild(window.famobi.menu.fgOverlay); window.famobi.menu.fgOverlay.innerHTML = '<header id="fg-header"><div class="fg-clip" id="fg-clip"><div class="fg-clip-btn"><span></span></div></div></header>'; window.famobi.menu.fgNavigation = document.createElement("nav"); window.famobi.menu.fgNavigation.style.position = "relative"; window.famobi.menu.fgNavigation.setAttribute("id", "fg-navigation"); window.famobi.menu.fgOverlay.appendChild(window.famobi.menu.fgNavigation); window.famobi.menu.fgOverlay_visible = false; window.famobi.menu.fgHeader = document.getElementById("fg-header"); faZepto("#fg-clip, #fg-logo").each(function() { window.famobi.menu.handleClick(this, window.famobi.menu.toggleOverlay); }); let currlang = window.famobi.getCurrentLanguage(); //console.log("currlang: "+currlang); let langButtons = ""; if(window.famobi.config.supportedLanguages && window.famobi.config.supportedLanguages.length > 1) { langButtons = '<ul class="fg-langs">'; let lang = ""; for(let l in window.famobi.config.supportedLanguages) { lang = window.famobi.config.supportedLanguages[l]; langButtons += `<li class="${(lang == currlang) ? 'fg-lang fg-lang-selected' : 'fg-lang'}" data-switch-lang="${lang}" style="cursor: pointer;"> <a href="javascript:void(0);"> <img class="fg-flag" src="html5games/images/flags/flag_${lang}.png" alt="${lang}"> <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 841.9 459" xml:space="preserve"> <path d="M630.7,227.3"></path> <path d="M21.5,17.9c-3.9,0-7.4,2.3-8.9,6c-1.6,3.7-0.6,7.8,2.1,10.5l399.7,399.7c1.9,1.9,4.5,2.9,6.8,2.9c2.3,0,5.1-1,6.8-2.9 L827.4,34.7c2.7-2.5,3.7-6.8,2.1-10.7c-1.6-3.7-5.1-6-8.9-6H21.5z"></path> </svg> </a> </li>`; } langButtons += '</ul>'; } //console.log(window.famobi.config.game_i18n); let menuButtons = (window.famobi.hasFeature("highscores")) ? `<ul class="fa-menu-buttons"> <li data-famobi-href="leaderboard"> <a href="javascript:void(0);" class="fa-menu-button-leaderboard"> <img src="html5games/images/leaderboard2.svg" alt="leaderboard"> </a> </li> </ul>` : ""; var menuHtml = `${menuButtons} <ul class="fg-related-games"> <li> <a href="${window.famobi.config.branding_url || window.famobi.config.more_games_url}" target="_blank"> <img src="html5games/images/icon.svg" alt="${window.famobi.config.name}"> </a> </li> </ul> ${langButtons}`; window.famobi.menu.setHtml(menuHtml); if(window.famobi.config.menuless) { window.famobi.menu.fgOverlay.style.display = "none"; } }, show: function() { if (window.famobi.menu.fgOverlay_visible) { return window.famobi.menu; } let leaderboardBtnImage = window.famobi.menu.fgNavigation.querySelector(".fa-menu-button-leaderboard img"); if(leaderboardBtnImage) { window.famobi.menu.fgNavigation.querySelector(".fa-menu-button-leaderboard img").style.animation = "growAndShake 1s linear 1s 1 forwards"; setTimeout(()=>window.famobi.menu.fgNavigation.querySelector(".fa-menu-button-leaderboard img").style.animation = "none",2000); } var $fullscreenIcon = faZepto("#fg-overlay .fa-menu-button-fullscreen"); this.hideAll(); window.famobi.menu.eventHandler = window.famobi.menu.handleClick(faZepto("html").get(0), this.hideAll); faZepto("html").get(0).style.cursor = "pointer"; if ( !document.fullscreenElement && !document.mozFullScreenElement && !document.webkitFullscreenElement && !document.msFullscreenElement ) { $fullscreenIcon .removeClass("fa-fullscreen-enabled") .addClass("fa-fullscreen-disabled"); } else { $fullscreenIcon .removeClass("fa-fullscreen-disabled") .addClass("fa-fullscreen-enabled"); } window.famobi.menu.fgOverlay_visible = true; faZepto(window.famobi.menu.fgOverlay).addClass("navigation-view"); window.famobi.menu.fgNavigation.style.display = ""; return window.famobi.menu; }, hide: function() { return hideAll(); }, hideAll: function() { if (!window.famobi.menu.fgOverlay_visible) { return window.famobi.menu; } if (window.famobi.menu.eventHandler) { window.famobi.menu.removeClick(faZepto("html").get(0), window.famobi.menu.eventHandler); } var $fgOverlay = faZepto(window.famobi.menu.fgOverlay); $fgOverlay.removeClass("iframe-view navigation-view fa-lang-shown"); window.famobi.menu.fgOverlay_visible = false; return window.famobi.menu; }, handleClick: function(element, callback) { var eventHandler = function(e) { callback.call(this, e); e.cancelBubble = true; e.stopPropagation(); return false; }; if (typeof callback === "function") { // http://stackoverflow.com/questions/13396297/windows-phone-8-touch-support // // Performing operations that require explicit user interaction on touchstart events is deprecated and will be removed in M54, around October 2016. See https://www.chromestatus.com/features/5649871251963904 for more details. if (window.navigator.msPointerEnabled) { element.addEventListener("MSPointerDown", eventHandler, false); } else if (window.PointerEvent) { element.addEventListener("pointerup", eventHandler, false); element.addEventListener("pointermove", this.eventTrap, true); element.addEventListener("pointerdown", this.eventTrap, true); } else if (detection.is.touch) { element.addEventListener("touchend", eventHandler, false); element.addEventListener("touchmove", this.eventTrap, true); element.addEventListener("touchstart", this.eventTrap, true); } else { element.addEventListener("click", eventHandler, false); } element.style.cursor = "pointer"; } return eventHandler; }, removeClick: function(element, eventHandler) { if (typeof eventHandler === "function") { if (window.navigator.msPointerEnabled) { element.removeEventListener("MSPointerDown", eventHandler, false); } else if (window.PointerEvent) { element.removeEventListener("pointerup", eventHandler, false); element.removeEventListener("pointermove", this.eventTrap, true); element.removeEventListener("pointerdown", this.eventTrap, true); } else if (detection.is.touch) { element.removeEventListener("touchend", eventHandler, false); element.removeEventListener("touchmove", this.eventTrap, true); element.removeEventListener("touchstart", this.eventTrap, true); } else { element.removeEventListener("click", eventHandler, false); } } return element; }, eventTrap: function(e) { e.preventDefault(); e.cancelBubble = true; e.stopPropagation(); }, toggleOverlay: function(e) { if (window.famobi.menu.fgOverlay_visible) { window.famobi.menu.hideAll(); } else { window.famobi.menu.show(); } e.stopPropagation(); return false; }, setHtml: function(html) { window.famobi.menu.fgNavigation.innerHTML = html; window.famobi.menu.bindEvents(); }, toggleLanguages: function() { var $overlayNode = faZepto(window.famobi.menu.fgOverlay); if ($overlayNode.hasClass("fa-lang-shown")) { $overlayNode.removeClass("fa-lang-shown"); } else { $overlayNode.addClass("fa-lang-shown"); } }, switchLanguage: function(lang) { var params = window.famobi.getUrlParams(), qs = ""; window.famobi.menu.hideAll(); params.locale = lang; qs = faZepto.param(params); document.location.replace( document.location.pathname + "?" + qs + (document.location.hash ? document.location.hash : "") ); }, bindEvents: function() { faZepto("[data-switch-lang]").each(function() { var $this = faZepto(this), lang = faZepto(this).attr("data-switch-lang"); $this.removeClass("fg-lang-selected"); if (lang === window.famobi.gametranslation.curLangString) { // Move selected language to first position $this.closest("ul").prepend($this); $this.addClass("fg-lang-selected"); } window.famobi.menu.handleClick(this, function() { if ($this.hasClass("fg-lang-selected") === true) { window.famobi.menu.toggleLanguages(); } else { if (lang.length) { window.famobi.menu.switchLanguage(lang); } } }); }); faZepto("[data-famobi-href]") .css("cursor", "pointer") .each(function() { var callback = function() { var link = faZepto(this).attr("data-famobi-href"); window.famobi.menu.hideAll(); switch (link) { case "moreGames": return window.famobi.menu.moreGamesLink(); case "back": return window.famobi.menu.backLink(); case "leaderboard": return window.famobi.showLeaderboard(); default: if (this.href) { window.open(this.href, ""); return false; } } }; window.famobi.menu.handleClick(this, callback.bind(this)); }); } }, getMoreGamesButtonImage: function() { return this.brandingLogo ? this.brandingLogo.src : "html5games/images/" + (this.config.more_games_button_image || "logo") + ".png"; }, getBrandingButtonImage: function() { return this.brandingLogo ? this.brandingLogo.src : "html5games/images/" + (this.config.branding_button_image || this.config.more_games_button_image || "logo") + ".png"; }, moreGamesLink: function() { var url = "https://famobi.com"; if(url = this.config.more_games_url) { window.open(url, "") || (window.top.location.href = url); } else { return; confirm("redirecting to... " + url) && (window.open(url, "") || (window.top.location.href = url)); // handles the link target in production version, depends on user language } }, openBrandingLink: function() { this.moreGamesLink(); }, localStorage: { setItem: function(key, value) { window.localStorage.setItem(window.famobi_gameID + ":" + key, value); }, getItem: function(key) { return window.localStorage.getItem(window.famobi_gameID + ":" + key); }, removeItem: function(key) { window.localStorage.removeItem(window.famobi_gameID + ":" + key); }, clear: function() { for (var key in window.localStorage) { if (key.startsWith(window.famobi_gameID + ":")) { window.localStorage.removeItem(key); } } } }, log: function() { if(this.config && !this.config.logging) { return; } console.log(arguments.length === 1 ? arguments[0] : arguments); }, warn: function() { if(this.config && !this.config.logging) { return; } console.warn(arguments.length === 1 ? arguments[0] : arguments); }, orientation: { init: function() { this.rootElement = document.getElementById("fg-root"); this.update(window.famobi.config.gameParams.orientation); }, update: function(orientation) { // show rotation screen? if ( typeof orientation != "undefined" && (window.famobi.config.rotation || (window.famobi.config.rotation !== false && !detection.is.pc && !detection.is.tablet)) && window.screen && window.screen.height !== window.screen.width ) { this.rootElement.className = this.rootElement.className + " fg-orientation-" + orientation; if (typeof this.fgLandscapeOverlay == "undefined") { this.fgLandscapeOverlay = document.createElement("div"); this.fgLandscapeOverlay.setAttribute("id", "fg-landscape-overlay"); this.fgLandscapeImage = document.createElement("img"); this.fgLandscapeImage.setAttribute( "src", "html5games/images/RotateToLandscape.png" ); this.fgLandscapeImage.setAttribute("class", "fg-orientation-icon"); this.fgLandscapeImage.setAttribute("alt", "switch to landscape"); this.fgLandscapeOverlay.appendChild(this.fgLandscapeImage); this.rootElement.appendChild(this.fgLandscapeOverlay); } if (typeof this.fgPortraitOverlay == "undefined") { this.fgPortraitOverlay = document.createElement("div"); this.fgPortraitOverlay.setAttribute("id", "fg-portrait-overlay"); this.fgPortraitImage = document.createElement("img"); this.fgPortraitImage.setAttribute( "src", "html5games/images/RotateToPortrait.png" ); this.fgPortraitImage.setAttribute("class", "fg-orientation-icon"); this.fgPortraitImage.setAttribute("alt", "switch to portrait"); this.fgPortraitOverlay.appendChild(this.fgPortraitImage); this.rootElement.appendChild(this.fgPortraitOverlay); } } return this; } }, sizeOf: function(data) { var length = 0; var prop; if (!data) { return length; } if (typeof data.length != "undefined") { return data.length; } if (Object.keys) { // available since ECMAScript 5 and in some browser 10x faster length = Object.keys(data).length; } else { for (prop in data) { if (data.hasOwnProperty(prop)) { length++; } } } return length; }, getOrientation: function() { var orientationMatch = window.matchMedia('all and (orientation:landscape)'); if(orientationMatch && orientationMatch.matches === true) { return 'landscape'; } return 'portrait'; }, onOrientationChange: function(callback) { this.orientationChangeCallback = callback; if (typeof callback !== "function") { this.error("famobi.onorientationchange: no valid callback provided."); } return faZepto(window).resize(callback); }, // DEPRECATED FUNCTIONS submitHighscore: function(level, score, isTriggered) { !isTriggered && this.warn("famobi.submitHighscore is deprecated, please use famobi_analytics.trackEvent('EVENT_LEVELSCORE')instead: https://sites.google.com/a/famobi.com/api-docs/api-implementation/famobi-analytics"); }, levelUp: function() { this.warn("famobi.levelUp is deprecated, please use famobi_analytics.trackEvent('EVENT_LEVELSUCCESS') instead: https://sites.google.com/a/famobi.com/api-docs/api-implementation/famobi-analytics"); }, gameOver: function() { this.warn("famobi.gameOver is deprecated, please use famobi_analytics.trackEvent('EVENT_LEVELFAIL') instead: https://sites.google.com/a/famobi.com/api-docs/api-implementation/famobi-analytics"); }, includeCSS: function(href) { var head = document.getElementsByTagName('head')[0], link = document.createElement('link'); link.rel = 'stylesheet'; link.type = 'text/css'; link.href = href; head.appendChild(link); }, sendLiveScore: function(liveScore) { // todo }, hasRewardedAd: function() { return this.hasFeature("rewarded"); }, hasFeature: function(feature) { if(feature == "local") feature = "standalone"; return this.config.features && this.config.features[feature] ? true : false; }, getAppLink: function() { return ""; }, getUrlParams: function(a, b, c) { a = /[?&]?([^=]+)=([^&]*)/g, b = document.location && document.location.search ? document.location.search.split("+").join(" ") : ""; for (var d = {}; c = a.exec(b);) d[decodeURIComponent(c[1])] = decodeURIComponent(c[2]); if(d['fg_aid']) { this.config.aid = d['fg_aid']; } else { d['fg_aid'] = this.config.aid; } return d; }, showLeaderboard: function() { if(!window.famobi.hasFeature("highscores")) return; }, game: { waitingCounter: 0, setWaiting: function(newVal) { newVal ? this.waitingCounter++ : this.waitingCounter > 0 ? this.waitingCounter-- : (this.waitingCounter = 0); return this; }, isWaiting: function() { return this.waitingCounter > 0; }, canResume: function() { return this.waitingCounter === 1; }, init: function() { this.waitingCounter = 0; }, pause: function() { if (this.isWaiting()) { //window.famobi..log('game is already waiting, do not pause'); this.setWaiting(true); return false; } this.setWaiting(true); try { if (typeof window.famobi_onPauseRequested == "function") { window.famobi_onPauseRequested(); return true; } // Phaser if (window.game && typeof window.game.paused !== "undefined") { window.game.paused = true; return true; } // Construct 2 if (typeof window.cr_setSuspended !== "undefined") { cr_setSuspended(true); //faZepto('<iframe id="fg-clickthrough-frame" src="about:blank" style="width: 100%; height: 100%; display: block; position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 999"></iframe>').appendTo(window.famobi..rootElement); return true; } // CreateJS <3 if (typeof window.createjs !== "undefined") { //window.createjs.Sound.setMute(true); } } catch (e) { window.famobi.log("Pausing game failed: " + e); } }, resume: function() { if (!this.isWaiting()) { //window.famobi..log('game is not waiting, do not resume'); return false; } if (!this.canResume()) { //window.famobi..log('game is still waiting, do not resume'); this.setWaiting(false); return false; } this.setWaiting(false); try { if (typeof window.famobi_onResumeRequested == "function") { window.famobi_onResumeRequested(); return true; } // Phaser if (window.game && typeof window.game.paused !== "undefined") { window.game.paused = false; return true; } // Construct 2 if (typeof window.cr_setSuspended !== "undefined") { cr_setSuspended(false); //faZepto('iframe#fg-clickthrough-frame').remove(); return true; } // CreateJS <3 if (typeof window.createjs !== "undefined") { //window.createjs.Sound.setMute(false); } } catch (e) { window.famobi.log("Resuming game failed: " + e); } return false; } }, "adapters": { // TODO init: function() { }, list: function() { }, add: function(section, subsection, callback) { }, has: function(section, subsection) { }, run: function(section, subsection) { } } }; // export famobi object to global object b[a] = famobi; }('famobi', window); var isPageReady = new Promise(function(resolve, reject) { var readyRE = /complete|loaded|interactive/; if (readyRE.test(document.readyState) && document.body) { resolve(); } else { document.addEventListener('DOMContentLoaded', resolve, false); } }); isPageReady.then(function() { return window.famobi.init(); }).then(function() { Promise.all((window.famobi.config.ads && !!window.famobi.config.ads.show_initial) ? [window.famobi.showInterstitialAd(true)] : []).then(function() { setTimeout(function() { (function next() { if (!window.famobi_gameJS.length) { window.famobi.gametranslation.init(); window.famobi.menu.create(); window.famobi.orientation.init(); window.setTimeout(function() { var e = document.createEvent('Events'); e.initEvent("deviceready", true, false); document.dispatchEvent(e); }, 50); return; } var currentScript = window.famobi_gameJS.shift(); if (typeof currentScript === "function") { if(typeof Zepto !== "undefined" && typeof window.faZepto === "undefined") { window.faZepto = Zepto; // see https://github.com/blai/fashionista/issues/2 ;(function ($) { $.getScript = function(src, func, error_func) { var script = document.createElement('script'); script.async = "async"; script.src = src; if (func) { script.onload = func; } if (error_func) { script.onerror = error_func; } document.getElementsByTagName("head")[0].appendChild( script ); }; })(Zepto); } currentScript(); next(); } else { var scriptEl = document.createElement("script"); scriptEl.onload = next; scriptEl.onerror = next; scriptEl.src = currentScript; document.body.appendChild(scriptEl); } })(); }, window.famobi.config.nextTimeout || 0); }); }); } v1/play.css 0000644 00000325272 15043717150 0006567 0 ustar 00 #fg-root img { position: static } *, :focus { -webkit-tap-highlight-color: rgba(255, 255, 255, 0)!important; -webkit-focus-ring-color: rgba(255, 255, 255, 0)!important; outline: none!important } canvas { touch-action: none; -ms-touch-action: none } #fg-root { font-family: Helvetica, Verdana, sans-serif; z-index: 99990; text-align: left; height: 0; width: 0; font-size: 13px; -webkit-transform: translateZ(0deg); transform: translateZ(0deg) } #fg-root * { -webkit-touch-callout: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; box-sizing: initial } #fg-root a { cursor: pointer } #fg-root #fg-overlay { box-sizing: border-box; position: fixed; z-index: 99990; top: 10px; left: -80px; width: 80px; background-color: rgba(0, 0, 0, 0.2); transition: left 0.5s, width .25s; transition-delay: .15s } #fg-root #fg-overlay * { padding: 0; margin: 0 } #fg-root #fg-overlay.iframe-view { width: auto; left: 0; right: 50px; bottom: 10px; max-width: 480px } #fg-root #fg-overlay.iframe-view #fg-back { display: block } #fg-root #fg-overlay.iframe-view #fg-close { display: block } #fg-root #fg-overlay.iframe-view #fg-logo { margin: 0 36px } #fg-root #fg-overlay.iframe-view .fg-clip { right: -50px } #fg-root #fg-overlay #fg-header { width: 100% } #fg-root #fg-overlay #fg-back { float: left; display: none } #fg-root #fg-overlay #fg-back:before { border-color: #FFF } #fg-root #fg-overlay #fg-logo { margin: 0 } #fg-root #fg-overlay #fg-logo img { height: 30px; padding: 3px 10px 0; width: 130px } #fg-root #fg-overlay .fg-clip { display: block; position: absolute; height: 38px; width: 35px; top: 0; right: -35px; background-color: transparent; z-index: 3000 } #fg-root #fg-overlay .fg-clip-btn { padding-top: 15px; box-sizing: border-box; height: 36px; width: 24px; background-color: rgba(0, 0, 0, 0.2) } #fg-root #fg-overlay .fg-clip-btn span, #fg-root #fg-overlay .fg-clip-btn span:before, #fg-root #fg-overlay .fg-clip-btn span:after { position: relative; display: block; width: 5px; height: 5px; margin-left: 9px; background-color: #fff; border-radius: 50%; text-indent: -10000px } #fg-root #fg-overlay .fg-clip-btn span:before, #fg-root #fg-overlay .fg-clip-btn span:after { content: ''; margin-left: 0; position: absolute; top: -8px; left: 0 } #fg-root #fg-overlay .fg-clip-btn span:after { top: 8px } #fg-root #fg-overlay ul { margin: 0; padding: 0; list-style: none } #fg-root #fg-overlay ul.fa-menu-buttons { margin: 5px; } #fg-root #fg-overlay ul.fa-menu-buttons li { display: inline-block; margin: 0; padding: 5px } #fg-root #fg-overlay ul.fa-menu-buttons li a { display: block; box-sizing: border-box; /*padding: 14px;*/ width: 60px; height: 60px; background-color: transparent/*#fff*/; box-shadow: 0 0 6px rgba(0, 0, 0, 0.4) } #fg-root #fg-overlay ul.fa-menu-buttons li a svg { display: block!important; width: 100%; height: 100%; fill: #333 } #fg-root #fg-overlay ul.fa-menu-buttons li a.fa-menu-button-leaderboard img { animation: none; } @keyframes growAndShake { 0% {transform: scale(1) rotate(0deg);} 15% {transform: scale(2) rotate(0deg);} 35% {transform: scale(2) rotate(20deg);} 50% {transform: scale(2) rotate(-20deg);} 65% {transform: scale(2) rotate(20deg);} 75% {transform: scale(2) rotate(-20deg);} 85% {transform: scale(2) rotate(0deg);} 100% {transform: scale(1) rotate(0deg);} } #fg-root #fg-overlay ul.fa-menu-buttons li a.fa-menu-button-back { background-color: #4bb000 } #fg-root #fg-overlay ul.fa-menu-buttons li a.fa-menu-button-back svg { fill: #fff } #fg-root #fg-overlay ul.fa-menu-buttons li a.fa-menu-button-fullscreen.fa-fullscreen-disabled svg.fa-fullscreen-icon-enabled { display: none!important } #fg-root #fg-overlay ul.fa-menu-buttons li a.fa-menu-button-fullscreen.fa-fullscreen-enabled svg.fa-fullscreen-icon-disabled { display: none!important } #fg-root #fg-overlay ul.fa-menu-buttons+ul.fg-related-games { /* border-top: 1px solid rgba(255, 255, 255, 0.4); */ } #fg-root #fg-overlay ul.fg-langs { padding: 5px } #fg-root #fg-overlay ul.fg-langs li.fg-lang { cursor: pointer; display: none; margin: 5px } #fg-root #fg-overlay ul.fg-langs li.fg-lang a { display: block; width: 60px; height: 32px; background-color: #ddd; padding: 2px; box-sizing: border-box } #fg-root #fg-overlay ul.fg-langs li.fg-lang.fg-lang-selected { display: inline-block; text-align: left } #fg-root #fg-overlay ul.fg-langs li.fg-lang.fg-lang-selected a { background-color: #fff; box-shadow: 0 0 6px rgba(0,0,0,0.4); position: relative } #fg-root #fg-overlay ul.fg-langs li.fg-lang.fg-lang-selected a .fg-flag { margin: 4px; border: 1px solid #ccc } #fg-root #fg-overlay ul.fg-langs li.fg-lang.fg-lang-selected a svg { display: block; position: absolute; top: 14px; right: 6px; width: 11px; fill: #333 } #fg-root #fg-overlay ul.fg-related-games { padding: 5px; box-sizing: border-box } #fg-root #fg-overlay ul.fg-related-games li { cursor: pointer; display: inline-block; margin: 5px 5px 5px -90px; transition: margin .5s; transition-delay: .2s } #fg-root #fg-overlay ul.fg-related-games li:nth-child(2) { transition-delay: .3s } #fg-root #fg-overlay ul.fg-related-games li:nth-child(3) { transition-delay: .4s } #fg-root #fg-overlay ul.fg-related-games li:nth-child(4) { transition-delay: .5s } #fg-root #fg-overlay ul.fg-related-games li a { position: relative; display: block; box-sizing: border-box; padding: 4px; width: 60px; height: 60px; background-color: #fff; box-shadow: 0 0 6px rgba(0, 0, 0, 0.4) } #fg-root #fg-overlay ul.fg-related-games li a img { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-65%); width: 90%; } #fg-root #fg-overlay ul.fg-related-games+ul.fg-langs { border-top: 1px solid rgba(255, 255, 255, 0.4) } #fg-root #fg-overlay.fa-lang-shown { width: 150px } #fg-root #fg-overlay.fa-lang-shown ul.fg-related-games li { transition: none } #fg-root #fg-overlay.fa-lang-shown ul.fg-langs li.fg-lang { display: inline-block; text-align: center } #fg-root #fg-overlay.fa-lang-shown ul.fg-langs li.fg-lang a svg { display: none } #fg-root #fg-overlay.fa-lang-shown ul.fg-langs li.fg-lang.fg-lang-selected a .fg-flag { margin: 4px 0 0 } #fg-root #fg-overlay.fa-lang-shown ul.fg-langs li.fg-lang.fg-lang-selected a svg { display: none } #fg-root #fg-overlay a .fg-flag { max-height: 18px; margin-top: 4px } #fg-root #fg-overlay.navigation-view { left: 0; right: 10px } #fg-root #fg-overlay.navigation-view .fg-clip { width: 55px; right: -55px } #fg-root #fg-overlay.navigation-view .fg-clip .fg-clip-btn { width: 44px; padding-top: 8px } #fg-root #fg-overlay.navigation-view .fg-clip .fg-clip-btn span { position: relative; display: inline-block; width: 20px; height: 20px; margin-left: 12px; border-radius: 0; background: none; overflow: hidden } #fg-root #fg-overlay.navigation-view .fg-clip .fg-clip-btn span:before, #fg-root #fg-overlay.navigation-view .fg-clip .fg-clip-btn span:after { border-radius: 5px; height: 3px; margin-top: -2px; content: ''; position: absolute; width: 100%; top: 50%; left: 0; background: #fff } #fg-root #fg-overlay.navigation-view .fg-clip .fg-clip-btn span:before { -webkit-transform: rotate(45deg); transform: rotate(45deg) } #fg-root #fg-overlay.navigation-view .fg-clip .fg-clip-btn span:after { -webkit-transform: rotate(-45deg); transform: rotate(-45deg) } #fg-root #fg-overlay.navigation-view ul.fg-related-games li { margin-left: 5px } #fg-root .fg-app-overlay { position: fixed; bottom: -150px; left: 0; right: 0; z-index: 999999900; transition: bottom 1s ease-out } #fg-root .fg-app-overlay .fg-app-teaser { display: block; background-color: #fff; border: 1px solid #eee; width: 340px; max-width: 96%; margin: 0 auto; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-weight: 300; font-size: 17px; line-height: 1.2em } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner { display: flex; padding: 5px; padding-bottom: 0; position: relative } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner a { text-decoration: none; color: #333 } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-close { display: block; width: 20px; height: 20px; position: absolute; top: 3px; right: 3px; background: url() no-repeat 0 0; background-size: 20px auto } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-icon { width: 60px; -ms-flex-shrink: 0; flex-shrink: 0; margin-right: 10px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-icon img { width: 100% } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta { width: 100% } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .titleHolder { display: flex } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta p { margin: 0; font-size: 13.5px; line-height: 130%; color: #333; font-weight: 400; white-space: nowrap; width: 70%; overflow: hidden } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta ul.fg-app-teaser-rating { list-style: none; padding: 0; margin: -3px 0 2px 7px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta ul.fg-app-teaser-rating li { display: inline-block; width: 10px; height: 10px; background: url() no-repeat 0 0; background-size: 10px auto!important } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta ul.fg-app-teaser-rating li.fg-app-teaser-rating-half { background-position: 0 -12px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta ul.fg-app-teaser-rating li.fg-app-teaser-rating-empty { background-position: 0 -25px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta ul.fg-app-teaser-rating li+li { margin-left: 2px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder { display: flex; justify-content: space-between; -webkit-justify-content: space-between; align-items: center; -webkit-align-items: center; margin-top: 6px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder .cta { -ms-flex-shrink: 0; flex-shrink: 0; margin-right: 30px } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder .cta a { position: relative } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder .cta a .fg-app-teaser-storeIcon { position: absolute; top: 0; left: 5px; width: 20px; height: 23px; display: inline-block; vertical-align: bottom; background-position: 0 0!important; background-repeat: no-repeat!important } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder .cta a .fg-app-teaser-storeIcon.fg-app-teaser-storeIcon-appStore { background: url(); width: 23px; background-size: 23px auto!important } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder .cta a .fg-app-teaser-storeIcon.fg-app-teaser-storeIcon-playStore { background: url(); background-size: 20px auto!important } #fg-root .fg-app-overlay .fg-app-teaser .fg-app-teaser-inner .fg-app-teaser-meta .ctaHolder .cta a span { display: inline-block; padding: 11px 11px 11px 34px; background-color: #669f2b; color: #fff; font-size: 13.5px; line-height: 100%; white-space: nowrap; font-weight: 500; text-transform: uppercase } @media only screen and (orientation: landscape) { #fg-root #fg-overlay.isMobile { width: 430px; left: -430px } #fg-root #fg-overlay.isMobile ul.fa-menu-buttons { display: inline-block; vertical-align: top; padding: 5px 0 5px 5px; margin: 0 } #fg-root #fg-overlay.isMobile ul.fg-related-games { display: inline-block; vertical-align: top; padding: 5px 5px 5px 0; height: 70px; overflow: hidden; border-top: 0!important } #fg-root #fg-overlay.isMobile ul.fg-related-games li { display: inline-block; margin: 5px 5px 5px -300px } #fg-root #fg-overlay.isMobile ul.fg-langs li.fg-lang { display: inline-block; vertical-align: top; text-align: center } #fg-root #fg-overlay.isMobile ul.fg-langs li.fg-lang svg { display: none } #fg-root #fg-overlay.isMobile ul.fg-langs li.fg-lang.fg-lang-selected a svg { display: none!important } #fg-root #fg-overlay.isMobile.navigation-view { left: 0 } #fg-root #fg-overlay.isMobile.navigation-view ul.fg-related-games li { margin-left: 5px } } @media only screen and (orientation: landscape) and (max-width: 479px) { #fg-root #fg-overlay.isMobile { width: 360px; left: -360px } #fg-root #fg-overlay.isMobile ul.fg-related-games li:nth-child(4) { display: none } } @media only screen and (orientation: portrait) and (max-height: 509px) { #fg-root #fg-overlay.isMobile ul.fg-related-games li:nth-child(4) { display: none } } #fg-root .fg-modal { position: fixed; top: 0; right: 0; bottom: 0; left: 0; margin: 0 auto; max-width: 480px; z-index: 999999990; box-sizing: border-box } #fg-root .fg-modal.seamless-mode { background: transparent none; border: 0; top: 0; right: 0; bottom: 0; left: 0 } #fg-root .fg-modal.seamless-mode header { display: none } #fg-root .fg-modal.seamless-mode .fg-modal-body { margin-top: 0; left: 0; right: 0; bottom: 0; background-color: transparent; box-shadow: none } #fg-root .fg-modal.fg-modal-shake { -webkit-animation: fg-modal-shake 1s 1 linear; animation: fg-modal-shake 1s 1 linear } #fg-root .fg-modal.ad-mode { top: 40px } #fg-root .fg-modal header { height: 20px; top: 0; right: 0; left: 0; position: absolute; line-height: 20px; margin: 15px 50px 15px 10px; color: #FFF; box-sizing: border-box; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 14px; text-shadow: 0 0 3px #000 } #fg-root .fg-modal .fg-modal-body { position: absolute; top: 0; left: 10px; right: 10px; bottom: 10px; overflow: hidden; -webkit-overflow-scrolling: touch; margin-top: 50px; background-color: #FFF; box-shadow: 0 0 10px rgba(0, 0, 0, 0.4) } #fg-root .fg-modal .fg-modal-body.fg-modal-transparent { background-color: transparent } #fg-root .fg-modal-close { box-sizing: border-box; position: absolute; top: 0; right: 0; color: #FFF; text-align: center; width: 50px; height: 50px; text-decoration: none; z-index: 100; line-height: 13px; padding: 19px 10px 18px; cursor: pointer } #fg-root .fg-modal-close:after { content: ""; box-sizing: border-box; position: absolute; top: 10px; right: 10px; width: 30px; height: 30px; border: 2px solid #FFF; background-color: rgba(0, 0, 0, 0.8); border-radius: 40px } #fg-root .fg-modal-close:before, #fg-root .fg-modal-close .counter { font-weight: 700; position: relative; z-index: 1 } #fg-root .fg-modal-close:before { content: "X" } #fg-root .fg-modal-close[data-disable]:after { background-color: rgba(0, 0, 0, 0.4) } #fg-root .fg-modal-close[data-disable]:before { display: none } #fg-root .fg-modal-overlay { position: fixed; top: 0; right: 0; bottom: 0; left: 0; background-color: #000; z-index: 100500 } @-webkit-keyframes fg-modal-shake { 0%, 100% { -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0) } 10%, 30%, 50%, 70%, 90% { -webkit-transform: translate3d(-10px, 0, 0); transform: translate3d(-10px, 0, 0) } 20%, 40%, 60%, 80% { -webkit-transform: translate3d(10px, 0, 0); transform: translate3d(10px, 0, 0) } } @keyframes fg-modal-shake { 0%, 100% { -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0) } 10%, 30%, 50%, 70%, 90% { -webkit-transform: translate3d(-10px, 0, 0); transform: translate3d(-10px, 0, 0) } 20%, 40%, 60%, 80% { -webkit-transform: translate3d(10px, 0, 0); transform: translate3d(10px, 0, 0) } } #fg-root .fg-notify { position: fixed; top: 0; right: 0; bottom: 0; left: 0; margin: 0 auto; z-index: 999999990; box-sizing: border-box; display: flex; align-items: center; max-width: 600px; width: 100%; padding: 10px } #fg-root .fg-notify .fg-notify-body { position: relative; -webkit-overflow-scrolling: touch; background-color: #F0F0F0; box-shadow: 0 0 10px rgba(0, 0, 0, 0.4); border-radius: 10px; padding: 10px; width: 100%; margin-top: 10px; box-sizing: border-box } #fg-root .fg-notify .fg-notify-body .fg-notify-gameteaser-holder { display: block; width: 100%; text-align: center } #fg-root .fg-notify .fg-notify-body .fg-notify-gameteaser-holder img { width: 50px; height: 50px; margin-top: -25px; border: 4px solid #fff; box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2) } #fg-root .fg-notify .fg-notify-body .fg-notify-header { margin-bottom: 10px } #fg-root .fg-notify .fg-notify-body .fg-notify-headline { display: block; width: 100%; margin: 5px 0 0; text-align: center; color: #333; font-weight: 300; font-size: 140% } #fg-root .fg-notify .fg-notify-body ul { list-style: none; padding: 0; margin: -5px; display: flex; flex-wrap: wrap; justify-content: center } #fg-root .fg-notify .fg-notify-body ul li { width: 50%; position: relative; padding: 0; padding-top: 50% } #fg-root .fg-notify .fg-notify-body ul li a { position: absolute; top: 0; left: 0; display: inline-block; padding: 5px; width: 100%; box-sizing: border-box } #fg-root .fg-notify .fg-notify-body ul li a .fg-notify-imgHolder { display: block; padding: 5px; background-color: #fff; box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2) } #fg-root .fg-notify .fg-notify-body ul li a .fg-notify-imgHolder img { display: block; width: 100% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard { position: relative; font-size: 90%; color: #333 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .hide { display: none!important } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner { display: block; background-color: #ffbf00; padding: 10px; margin-bottom: 20px; color: #fff; text-align: center } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner h2 { margin: 0 0 10px; font-weight: 400; text-transform: uppercase; font-size: 120% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong { display: inline-block; padding-left: 50px; text-align: left; font-size: 180%; position: relative } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong small { display: block; font-weight: 400; font-size: 80% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong:before { content: ''; position: absolute; left: 0; top: 0; display: block; width: 40px; height: 42px; background: url() no-repeat 0 0; background-size: 40px auto } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong .profileImageHolder { position: absolute; top: 16px; left: 20px; display: block; width: 24px; height: 24px; padding: 0; overflow: hidden; border-radius: 50% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong .profileImageHolder span { display: block; height: 8%; width: 100% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-headline h2 { text-align: center; text-transform: uppercase; font-weight: 400; margin-bottom: 5px; font-size: 150% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-currentscore { display: block; margin: 10px 0; text-align: center; font-weight: 700; color: #0096cc; font-size: 120% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-currentscore.newHighscore { color: #43b033 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you { position: -webkit-sticky; position: sticky; bottom: 0; left: 0; z-index: 2; display: block; width: 100%; background-color: #0096cc; box-shadow: 0 0 10px rgba(0, 0, 0, 0.4); display: flex } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div { padding: 10px 5px; box-sizing: border-box; color: #fff; font-size: 12px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div a { display: inline-block; margin: 3px 0; color: #fff; font-weight: 400 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div em { margin-right: 10px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div:last-child { text-align: right } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table { width: 100%; border-spacing: 0; font-size: 12px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr td, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr th { padding: 15px 5px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr td:last-child, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr th:last-child { text-align: right } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr th { padding: 10px 5px 5px; color: #888; font-weight: 400; text-transform: uppercase; font-size: 90% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr th em { font-style: 700; color: #333 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr:nth-child(even) td { background-color: #e3e3e3 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.you td { background-color: #0096cc; color: #fff } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.you td a { display: inline-block; margin: 3px 0; color: #fff } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.you td em { margin-right: 10px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td.rank, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th.rank, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div.rank { width: 25% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td.player, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th.player, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div.player { width: 43% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td.score, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th.score, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div.score { width: 28% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div.profileImage { width: 4%; min-width: 20px; margin-left: auto; padding: 10px 0 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td.profileImage .profileImageHolder, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th.profileImage .profileImageHolder, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div.profileImage .profileImageHolder { display: block; width: 20px; height: 20px; padding: 0; overflow: hidden; border-radius: 50% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td.profileImage .profileImageHolder span, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th.profileImage .profileImageHolder span, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div.profileImage .profileImageHolder span { display: block; height: 8%; width: 100% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table td em, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table th em, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div em { font-style: normal } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 td, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 div, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 td, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 div { font-weight: 700 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 div.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_2 td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_2 div.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_3 td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_3 div.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 div.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_2 td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_2 div.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_3 td.profileImage, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_3 div.profileImage { position: relative } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_2 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_2 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_3 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_3 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_2 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_2 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_3 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_3 div.profileImage:before { content: ''; position: absolute; left: -35px; top: 0; display: block; width: 30px; height: 100%; background-size: 30px auto; background-position: center center; background-repeat: no-repeat } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_1 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_1 div.profileImage:before { background-image: url() } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_2 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_2 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_2 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_2 div.profileImage:before { background-image: url() } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_3 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr.rank_3 div.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_3 td.profileImage:before, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you.rank_3 div.profileImage:before { background-image: url(); background-size: 23px auto } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-countdown-holder { margin-bottom: 10px; color: #777 } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-countdown, #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-totalplayers { text-align: center } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-editnick { display: none; margin-top: 20px; text-align: center } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-editnick h2 { font-weight: 400; font-size: 120% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-editnick input { display: block; width: 100%; max-width: 300px; padding: 5px; margin: 10px auto; box-sizing: border-box; border: 1px solid #ddd; font-size: 110%; -webkit-user-select: auto; -moz-user-select: auto; -ms-user-select: auto; user-select: auto } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-editnick a.saveNick { display: inline-block; background-color: #2EAC00; margin-right: 10px; padding: 8px 16px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.3); color: #fff; text-decoration: none; font-size: 110% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-editnick a.cancelEditNick { display: inline-block; color: #666; font-size: 110%; text-decoration: underline } #fg-root .fg-notify.editNick { display: block; height: 100% } #fg-root .fg-notify.editNick .fg-notify-body { height: 100% } #fg-root .fg-notify.editNick .fg-leaderboard .fg-leaderboard-editnick { display: block } #fg-root .fg-notify.editNick .fg-leaderboard .fg-leaderboard-lastroundwinner, #fg-root .fg-notify.editNick .fg-leaderboard .fg-leaderboard-headline, #fg-root .fg-notify.editNick .fg-leaderboard .fg-leaderboard-currentscore, #fg-root .fg-notify.editNick .fg-leaderboard .fg-leaderboard-countdown-holder, #fg-root .fg-notify.editNick .fg-leaderboard table, #fg-root .fg-notify.editNick .fg-leaderboard .fg-leaderboard-you { display: none } #fg-root .fg-notify-close { position: absolute; top: 10px; right: 10px; z-index: 100; border: 2px solid #2EAC00; border-radius: 50%; width: 28px; height: 28px; font-weight: 300; line-height: 25px; text-align: center; color: #2EAC00; font-size: 190%; text-decoration: none; cursor: pointer; box-shadow: 0 0 10px rgba(0, 0, 0, 0.3) } #fg-root .fg-notify-close:hover { background-color: #2EAC00; color: #fff } #fg-root .fg-notify-overlay, #fg-root .fg-notify-blurred-bg { position: fixed; top: 0; right: 0; bottom: 0; left: 0; background-color: rgba(0, 0, 0, 0.2); background-size: cover; background-position: center center; z-index: 100500 } @media only screen and (min-width: 375px) { #fg-root .fg-notify .fg-notify-body ul li { width: 33.3%; padding-top: 33.3% } } @media only screen and (min-width: 510px) { #fg-root .fg-notify .fg-notify-body { margin-top: 20px; padding: 20px } #fg-root .fg-notify .fg-notify-body .fg-notify-gameteaser-holder img { width: 80px; height: 80px; margin-top: -40px } #fg-root .fg-notify .fg-notify-body .fg-notify-headline { font-size: 200% } #fg-root .fg-notify .fg-notify-body ul li { width: 25%; padding-top: 25% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard { font-size: 100% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner { padding: 15px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong { padding-left: 70px; font-size: 240% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong:before { width: 60px; height: 62px; background-size: 60px auto } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-lastroundwinner strong .profileImageHolder { left: 30px; top: 24px; width: 36px; height: 36px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table { font-size: 110% } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr td { padding: 15px 10px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard table tr th { padding: 10px 10px 5px } #fg-root .fg-notify .fg-notify-body .fg-leaderboard .fg-leaderboard-you div { font-size: 110% } #fg-root .fg-notify-close { top: 20px; right: 20px } } #fg-root .btn, #fg-root .btn-highlight, #fg-root .btn-play, #fg-root .btn-primary, #fg-root .btn-transparent { display: inline-block; box-sizing: border-box; background-color: #eee; color: #333; padding: 10px 20px; border: 0; cursor: pointer; margin: 0; text-decoration: none; text-align: center; font-size: 16px; box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.2) } .btn-group #fg-root .btn, .btn-group #fg-root .btn-highlight, .btn-group #fg-root .btn-play, .btn-group #fg-root .btn-primary, .btn-group #fg-root .btn-transparent { margin-left: 5px } #fg-root .btn.btn-block, #fg-root .btn-block.btn-highlight, #fg-root .btn-block.btn-play, #fg-root .btn-block.btn-primary, #fg-root .btn-block.btn-transparent { display: block; width: 100% } #fg-root .btn[disabled], #fg-root [disabled].btn-highlight, #fg-root [disabled].btn-play, #fg-root [disabled].btn-primary, #fg-root [disabled].btn-transparent { opacity: .7 } #fg-root .btn-highlight, #fg-root .btn-play { background-color: #f08119; border: 1px solid #FFF; color: #FFF } #fg-root .btn-primary { background-color: #006d92; color: #FFF } #fg-root .btn-transparent { background-color: transparent; color: #333 } #fg-root .btn-play { background-color: #008c14; box-shadow: 0 1px 0 0 rgba(0, 0, 0, 0.75); position: relative; width: 65px; height: 65px; border-color: #008c14; border-radius: 50%; border-width: 2px; -webkit-animation-name: animate-btn-play; animation-name: animate-btn-play; -webkit-animation-duration: 2s; animation-duration: 2s; -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite; -webkit-animation-direction: alternate; animation-direction: alternate; -webkit-animation-timing-function: ease-in-out; animation-timing-function: ease-in-out } #fg-root .btn-play:after { content: ''; position: absolute; width: 0; height: 0; left: 23px; top: 18px; border: 13px solid transparent; border-left: 20px solid #fff; border-right: 0 } #fg-root .btn-play:before { content: "Continue"; content: attr(title); color: #fff; display: block; position: absolute; bottom: -25px; font-size: 14px; height: 20px; line-height: 20px; text-align: center; left: 50%; width: 200%; margin-left: -100% } #fg-root #fg-iframe-container { width: 100%; height: 100% } #fg-root #fg-storage-iframe, #fg-root .fg-post-iframe, #fg-root #fg-com-iframe { position: absolute; border: 0; left: -3000px; top: -3000px; opacity: 0; height: 1px; width: 1px } #fg-root #fg-iframe { border: 0; display: block; width: 100%; height: 100% } #fg-root .fg-spinner { display: none; visibility: hidden; position: fixed; top: 20%; margin-left: -37px; text-align: center; z-index: 999000; opacity: 0; transition: opacity .5s } #fg-root .fg-spinner [class*="fg-dot"] { position: absolute; height: 60px; width: 60px; opacity: 1 } #fg-root .fg-spinner [class*="fg-dot"]:before { content: ""; height: 15px; width: 7px; background-color: #fff; position: absolute; top: 5px; left: 0; right: 0; margin: 0 auto; border-radius: 10px; overflow: hidden } #fg-root .fg-spinner .fg-dot1 { -webkit-animation: fg-fade-spinner 1.2s infinite linear; animation: fg-fade-spinner 1.2s infinite linear } #fg-root .fg-spinner .fg-dot2 { -webkit-transform: rotate(51deg); transform: rotate(51deg); -webkit-animation: fg-fade-spinner 1.2s infinite linear .2s; animation: fg-fade-spinner 1.2s infinite linear .2s } #fg-root .fg-spinner .fg-dot3 { -webkit-transform: rotate(102deg); transform: rotate(102deg); -webkit-animation: fg-fade-spinner 1.2s infinite linear .4s; animation: fg-fade-spinner 1.2s infinite linear .4s } #fg-root .fg-spinner .fg-dot4 { -webkit-transform: rotate(153deg); transform: rotate(153deg); -webkit-animation: fg-fade-spinner 1.2s infinite linear .6s; animation: fg-fade-spinner 1.2s infinite linear .6s } #fg-root .fg-spinner .fg-dot5 { -webkit-transform: rotate(204deg); transform: rotate(204deg); -webkit-animation: fg-fade-spinner 1.2s infinite linear .8s; animation: fg-fade-spinner 1.2s infinite linear .8s } #fg-root .fg-spinner .fg-dot6 { -webkit-transform: rotate(255deg); transform: rotate(255deg); -webkit-animation: fg-fade-spinner 1.2s infinite linear 1s; animation: fg-fade-spinner 1.2s infinite linear 1s } #fg-root .fg-spinner .fg-dot7 { -webkit-transform: rotate(307deg); transform: rotate(307deg); -webkit-animation: fg-fade-spinner 1.2s infinite linear 1.2s; animation: fg-fade-spinner 1.2s infinite linear 1.2s } #fg-root #cssload-pgloading:after { content: ""; z-index: -1; position: absolute; top: 0; right: 0; bottom: 0; left: 0 } #fg-root #cssload-pgloading .cssload-loadingwrap { position: absolute; top: 45%; bottom: 45%; left: 25%; right: 25% } #fg-root #cssload-pgloading .cssload-bokeh { font-size: 85px; width: 1em; height: 1em; position: relative; margin: 0 auto; list-style: none; padding: 0; border-radius: 50%; -o-border-radius: 50%; -ms-border-radius: 50%; -webkit-border-radius: 50%; -moz-border-radius: 50% } #fg-root #cssload-pgloading .cssload-bokeh li { position: absolute; width: .2em; height: .2em; border-radius: 50%; -o-border-radius: 50%; -ms-border-radius: 50%; -webkit-border-radius: 50%; -moz-border-radius: 50% } #fg-root #cssload-pgloading .cssload-bokeh li:nth-child(1) { left: 50%; top: 0; margin: 0 0 0 -.1em; background: #0092c3; transform-origin: 50% 250%; -o-transform-origin: 50% 250%; -ms-transform-origin: 50% 250%; -webkit-transform-origin: 50% 250%; -moz-transform-origin: 50% 250%; animation: cssload-rota .6765s linear infinite, cssload-opa 2.2035s ease-in-out infinite alternate; -o-animation: cssload-rota .6765s linear infinite, cssload-opa 2.2035s ease-in-out infinite alternate; -ms-animation: cssload-rota .6765s linear infinite, cssload-opa 2.2035s ease-in-out infinite alternate; -webkit-animation: cssload-rota .6765s linear infinite, cssload-opa 2.2035s ease-in-out infinite alternate; -moz-animation: cssload-rota .6765s linear infinite, cssload-opa 2.2035s ease-in-out infinite alternate } #fg-root #cssload-pgloading .cssload-bokeh li:nth-child(2) { top: 50%; right: 0; margin: -.1em 0 0; background: #f08119; transform-origin: -150% 50%; -o-transform-origin: -150% 50%; -ms-transform-origin: -150% 50%; -webkit-transform-origin: -150% 50%; -moz-transform-origin: -150% 50%; animation: cssload-rota 1.113s linear infinite, cssload-opa 2.5745s ease-in-out infinite alternate; -o-animation: cssload-rota 1.113s linear infinite, cssload-opa 2.5745s ease-in-out infinite alternate; -ms-animation: cssload-rota 1.113s linear infinite, cssload-opa 2.5745s ease-in-out infinite alternate; -webkit-animation: cssload-rota 1.113s linear infinite, cssload-opa 2.5745s ease-in-out infinite alternate; -moz-animation: cssload-rota 1.113s linear infinite, cssload-opa 2.5745s ease-in-out infinite alternate } #fg-root #cssload-pgloading .cssload-bokeh li:nth-child(3) { left: 50%; bottom: 0; margin: 0 0 0 -.1em; background: #333; transform-origin: 50% -150%; -o-transform-origin: 50% -150%; -ms-transform-origin: 50% -150%; -webkit-transform-origin: 50% -150%; -moz-transform-origin: 50% -150%; animation: cssload-rota .8725s linear infinite, cssload-opa 3.076s ease-in-out infinite alternate; -o-animation: cssload-rota .8725s linear infinite, cssload-opa 3.076s ease-in-out infinite alternate; -ms-animation: cssload-rota .8725s linear infinite, cssload-opa 3.076s ease-in-out infinite alternate; -webkit-animation: cssload-rota .8725s linear infinite, cssload-opa 3.076s ease-in-out infinite alternate; -moz-animation: cssload-rota .8725s linear infinite, cssload-opa 3.076s ease-in-out infinite alternate } #fg-root #cssload-pgloading .cssload-bokeh li:nth-child(4) { top: 50%; left: 0; margin: -.1em 0 0; background: #fff; transform-origin: 250% 50%; -o-transform-origin: 250% 50%; -ms-transform-origin: 250% 50%; -webkit-transform-origin: 250% 50%; -moz-transform-origin: 250% 50%; animation: cssload-rota 1.036s linear infinite, cssload-opa 3.1525s ease-in-out infinite alternate; -o-animation: cssload-rota 1.036s linear infinite, cssload-opa 3.1525s ease-in-out infinite alternate; -ms-animation: cssload-rota 1.036s linear infinite, cssload-opa 3.1525s ease-in-out infinite alternate; -webkit-animation: cssload-rota 1.036s linear infinite, cssload-opa 3.1525s ease-in-out infinite alternate; -moz-animation: cssload-rota 1.036s linear infinite, cssload-opa 3.1525s ease-in-out infinite alternate } @keyframes cssload-rota { to { -webkit-transform: rotate(360deg); transform: rotate(360deg) } } @-webkit-keyframes cssload-rota { to { -webkit-transform: rotate(360deg) } } @keyframes cssload-opa { 12.0% { opacity: .8 } 19.5% { opacity: .88 } 37.2% { opacity: .64 } 40.5% { opacity: .52 } 52.7% { opacity: .69 } 60.2% { opacity: .6 } 66.6% { opacity: .52 } 70.0% { opacity: .63 } 79.9% { opacity: .6 } 84.2% { opacity: .75 } 91.0% { opacity: .87 } } @-webkit-keyframes cssload-opa { 12.0% { opacity: .8 } 19.5% { opacity: .88 } 37.2% { opacity: .64 } 40.5% { opacity: .52 } 52.7% { opacity: .69 } 60.2% { opacity: .6 } 66.6% { opacity: .52 } 70.0% { opacity: .63 } 79.9% { opacity: .6 } 84.2% { opacity: .75 } 91.0% { opacity: .87 } } #fg-root .fg-click2play { position: absolute; top: 0; left: 0; background: #000; display: block; width: 100%; min-height: 100%; text-align: center; z-index: 999999000; display: flex; align-items: center; opacity: 0 } #fg-root .fg-click2play, #fg-root .fg-click2play * { cursor: pointer; font-weight: 400 } #fg-root .fg-click2play .fg-branding { position: absolute; top: 0; left: 0; z-index: 1; width: 100%; height: 100%; opacity: .75 } #fg-root .fg-click2play .fg-click2play-loading { display: none; position: absolute; top: 50%; left: 0; width: 100%; text-align: center; margin-top: -8px } #fg-root .fg-click2play .fg-click2play-loading>span { display: inline-block; width: 14px; height: 14px; margin-left: 3px; background-color: #fff; border-radius: 100%; -webkit-animation: fg-click2play-loading 1.4s infinite ease-in-out both; animation: fg-click2play-loading 1.4s infinite ease-in-out both } #fg-root .fg-click2play .fg-click2play-loading>span.fg-click2play-loading-bounce1 { -webkit-animation-delay: -.32s; animation-delay: -.32s; margin-left: 0 } #fg-root .fg-click2play .fg-click2play-loading>span.fg-click2play-loading-bounce2 { -webkit-animation-delay: -.16s; animation-delay: -.16s } @-webkit-keyframes fg-click2play-loading { 0%, 80%, 100% { -webkit-transform: scale(0) } 40% { -webkit-transform: scale(1) } } @keyframes fg-click2play-loading { 0%, 80%, 100% { -webkit-transform: scale(0); transform: scale(0) } 40% { -webkit-transform: scale(1); transform: scale(1) } } #fg-root .fg-click2play .btn-play.loading .fg-click2play-loading { display: block } #fg-root .fg-click2play .btn-play.loading:after { opacity: 0 } #fg-root .fg-click2play .fg-click2play-stage { display: block; width: 100%; margin: 0; position: relative; z-index: 2; padding: 30px 0; background: rgba(0, 0, 0, 0.5) } #fg-root .fg-click2play .fg-click2play-stage .fg-gameicon { margin: 0 auto 30px } #fg-root .fg-click2play .fg-click2play-stage .fg-gameicon img { border: 1px solid #333; border-radius: 3px; max-height: 100%; max-width: 100%; width: 140px; height: 140px } #fg-root .fg-click2play .fg-click2play-stage .privacy-info { margin: 20px auto 0; padding: 0 10px; max-width: 420px; text-align: center; color: #ddd; line-height: 130%; font-size: 80%; text-shadow: 1px 1px #000 } #fg-root .fg-click2play .fg-click2play-stage .privacy-info strong { font-weight: 700 } #fg-root .fg-click2play .fg-click2play-stage .privacy-info p+p { margin-top: 5px } #fg-root .fg-click2play .fg-click2play-stage .privacy-info a { color: #fff; text-decoration: underline } #fg-root .fg-click2play.fg-click2play-continue .fg-click2play-stage .fg-gameDetails { display: flex; justify-content: center; -webkit-justify-content: center; -ms-flex-pack: center; align-items: center; flex-direction: row; flex-wrap: wrap } #fg-root .fg-click2play.fg-click2play-continue .fg-click2play-stage .fg-gameDetails .fg-gameicon { margin: 0 30px 0 0 } #fg-root .fg-click2play.fg-click2play-continue .fg-click2play-stage .fg-gameDetails .fg-gameicon:after { width: 150px } #fg-root .fg-click2play.fg-click2play-continue .fg-click2play-stage .privacy-info { display: none } #fg-root .fg-click2play.fg-click2play-continue .fg-click2play-stage .fg-gameLanguages, #fg-root .fg-click2play.fg-click2play-continue .fg-click2play-stage .fg-nextGame { flex: none } @media only screen and (orientation: landscape) { #fg-root .fg-click2play.smartphone .fg-click2play-stage .fg-gameDetails { display: flex; justify-content: center; -webkit-justify-content: center; -ms-flex-pack: center; align-items: center; flex-direction: row; flex-wrap: wrap } #fg-root .fg-click2play.smartphone .fg-click2play-stage .fg-gameDetails .fg-gameicon { margin: 0 60px 0 0 } #fg-root .fg-click2play.smartphone .fg-click2play-stage .fg-gameLanguages, #fg-root .fg-click2play.smartphone .fg-click2play-stage .fg-nextGame { flex: none } #fg-root .fg-click2play.smartphone .fa-getiton { padding: 0 } } @media only screen and (min-width: 640px) and (min-height: 550px) { #fg-root .fg-click2play .fg-click2play-stage .fg-gameicon img { width: 192px; height: 192px } #fg-root #fg-root .btn-play { width: 80px; height: 80px } #fg-root #fg-root .btn-play:after { left: 30px; top: 25px } } #fg-apps { background-color: #000; position: relative; top: 0; bottom: 0; left: 0; right: 0; display: block; height: 100%; min-height: 100% } #fg-apps .background { display: block; position: absolute; top: 0; bottom: 0; left: 0; right: 0; z-index: 10; background-size: cover; background-position: top center!important; background-repeat: no-repeat!important; background-attachment: fixed; opacity: .3 } #fg-apps article { display: block; width: 100%; position: absolute; top: 15px; left: 0; z-index: 20; text-align: center } #fg-apps article h1 { color: #fff; font-family: 'Lato', sans-serif; font-weight: 300; font-size: 120%; line-height: 100%; margin: 15px 0 } #fg-apps article h1 img { display: block; width: 100px; margin: 0 auto 15px } #fg-apps article ul.storeLinks { display: inline-block; list-style: none; padding: 0; margin: 15px 0 0 } #fg-apps article ul.storeLinks li { display: block } #fg-apps article ul.storeLinks li+li { margin-top: 15px } #fg-apps article ul.storeLinks li a { display: block; width: 150px; height: 46px; margin: 0 auto; text-indent: -10000px; background: url(../../../../../assets/images/StoreButtons.sprite.html) no-repeat center 0; background-size: auto 183px } #fg-apps article ul.storeLinks li.appStore a { background-position: 0 -67px } #fg-apps article ul.storeLinks li.browser a { background-position: 0 -134px } #fg-apps article .buttonContainer { margin: 20px 0 30px; text-align: center } #fg-apps article .buttonContainer .cta { display: inline-block; padding: 10px 60px; background-color: #4aa500; box-shadow: 0 0 10px rgba(0, 0, 0, 0.7); color: #fff; text-decoration: none; font-size: 230% } #fg-apps article .buttonContainer .cta:hover { background-color: #fff; color: #4aa500 } #fg-apps article .info { padding: 20px 10px 0; margin: 0; color: #bbb; line-height: 130% } #fg-apps article .info strong { display: block; margin-bottom: 5px } #fg-apps article .info a { color: #fff } @media (min-width: 480px) { #fg-apps article ul.storeLinks li { display: inline-block } #fg-apps article ul.storeLinks li+li { margin-top: 0; margin-left: 5px } } @media (min-height: 500px) { #fg-apps article { top: 30px } #fg-apps article h1 { font-size: 200% } #fg-apps article h1 img { width: 170px } #fg-apps article ul.storeLinks { margin-top: 30px } } #fg-root #fg-landscape-overlay, #fg-root #fg-portrait-overlay { z-index: 99900; display: none; position: fixed; top: 0; right: 0; bottom: 0; left: 0; width: 0; height: 0; overflow: hidden; background: #ddd url(../../../../../../img.cdn.famobi.com/html5games/gameapi/v1/images/RotateArrow.png) center center no-repeat; background-size: 145px 145px; box-shadow: inset 0 0 100px #333 } #fg-root #fg-landscape-overlay .fg-orientation-icon, #fg-root #fg-portrait-overlay .fg-orientation-icon { position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 145px; height: 145px; z-index: 2; margin: auto; -webkit-animation: fg-rotation 5s infinite linear; animation: fg-rotation 5s infinite linear } #fg-root #fg-splash-screen { z-index: 900000; display: block; position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; overflow: hidden; background: #8EC4E7 center center no-repeat; background-size: 200px 200px } #fg-root #fg-loading { cursor: pointer; position: absolute; top: 50%; left: 0; text-align: center; vertical-align: center; height: 20px; padding-top: 120px; width: 100%; z-index: 900010 } @-webkit-keyframes fg-rotation { 10% { -webkit-transform: rotate(0deg) } 30% { -webkit-transform: rotate(90deg) } 70% { -webkit-transform: rotate(90deg) } 90% { -webkit-transform: rotate(0deg) } } @-webkit-keyframes fg-fade-spinner { 0% { opacity: .6 } 15% { opacity: 1 } 60% { opacity: 1 } 100% { opacity: .6 } } @media only screen and (orientation: landscape) { #fg-root.fg-orientation-portrait #fg-portrait-overlay { display: block; width: 100%; height: 100% } #fg-root .fg-modal.ad-mode { top: 10px } } @media only screen and (orientation: portrait) { #fg-root.fg-orientation-landscape #fg-landscape-overlay { display: block; width: 100%; height: 100% } } #fg-root .fg-screenshot { position: relative } #fg-root .fg-screenshot>img { max-width: 100%; display: block } #fg-root #fg-fotoshoot-overlay { position: absolute; top: 5%; right: 5%; width: 36px; height: 36px; z-index: 99900 } #fg-root #fg-fotoshoot-overlay svg { fill: #fc6; background-color: #333; padding: 6px; display: block; border-radius: 7px; border: 1px solid #ccc } #fg-root .fg-screenshot-btn-upload, #fg-root .fg-screenshot-btn-discard { position: absolute; top: 0; left: 50.5%; right: 0; bottom: 0; text-align: center; background-color: rgba(255, 255, 255, 0.6); max-width: 200px; max-height: 200px; margin: auto } #fg-root .fg-screenshot-btn-upload:after, #fg-root .fg-screenshot-btn-discard:after { content: ''; display: block; width: 100%; height: 0; margin-bottom: 100% } #fg-root .fg-screenshot-btn-upload svg, #fg-root .fg-screenshot-btn-discard svg { position: absolute; left: 0; top: 15%; height: 70%; max-width: 100%; fill: green; -webkit-animation: fg-screenshot-show-buttons 1s 1 linear; animation: fg-screenshot-show-buttons 1s 1 linear; transition: fill 1s linear } #fg-root .fg-screenshot-btn-upload:before, #fg-root .fg-screenshot-btn-discard:before { content: ''; position: absolute; left: 0; right: 0; bottom: 0; display: block; height: 0; background-color: green; opacity: .4; transition: none } #fg-root .fg-screenshot-btn-upload.fg-screenshot-btn-loading svg, #fg-root .fg-screenshot-btn-loading.fg-screenshot-btn-discard svg { fill: #000; opacity: .6 } #fg-root .fg-screenshot-btn-upload.fg-screenshot-btn-loading:before, #fg-root .fg-screenshot-btn-loading.fg-screenshot-btn-discard:before { transition: height 15s linear; height: 90% } #fg-root .fg-screenshot-btn-upload.fg-screenshot-btn-loading-complete:before, #fg-root .fg-screenshot-btn-loading-complete.fg-screenshot-btn-discard:before { transition: height .5s linear; height: 100% } #fg-root .fg-screenshot-btn-upload.fg-screenshot-btn-loading-fail:before, #fg-root .fg-screenshot-btn-loading-fail.fg-screenshot-btn-discard:before { transition: none; background-color: red; height: 100% } #fg-root .fg-screenshot-btn-discard { left: 0; right: 50.5% } #fg-root .fg-screenshot-btn-discard svg { fill: red } @-webkit-keyframes fg-screenshot-show-buttons { 0%, 20%, 40%, 60%, 80%, 100% { transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1) } 0% { opacity: 0; -webkit-transform: scale3d(0.3, 0.3, 0.3); transform: scale3d(0.3, 0.3, 0.3) } 20% { -webkit-transform: scale3d(1.1, 1.1, 1.1); transform: scale3d(1.1, 1.1, 1.1) } 40% { -webkit-transform: scale3d(0.9, 0.9, 0.9); transform: scale3d(0.9, 0.9, 0.9) } 60% { opacity: 1; -webkit-transform: scale3d(1.03, 1.03, 1.03); transform: scale3d(1.03, 1.03, 1.03) } 80% { -webkit-transform: scale3d(0.97, 0.97, 0.97); transform: scale3d(0.97, 0.97, 0.97) } 100% { opacity: 1; -webkit-transform: scale3d(1, 1, 1); transform: scale3d(1, 1, 1) } } @keyframes fg-screenshot-show-buttons { 0%, 20%, 40%, 60%, 80%, 100% { transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1) } 0% { opacity: 0; -webkit-transform: scale3d(0.3, 0.3, 0.3); transform: scale3d(0.3, 0.3, 0.3) } 20% { -webkit-transform: scale3d(1.1, 1.1, 1.1); transform: scale3d(1.1, 1.1, 1.1) } 40% { -webkit-transform: scale3d(0.9, 0.9, 0.9); transform: scale3d(0.9, 0.9, 0.9) } 60% { opacity: 1; -webkit-transform: scale3d(1.03, 1.03, 1.03); transform: scale3d(1.03, 1.03, 1.03) } 80% { -webkit-transform: scale3d(0.97, 0.97, 0.97); transform: scale3d(0.97, 0.97, 0.97) } 100% { opacity: 1; -webkit-transform: scale3d(1, 1, 1); transform: scale3d(1, 1, 1) } } @-webkit-keyframes animate-btn-play { 0% { box-shadow: inset 0 0 0 transparent } 100% { box-shadow: inset 0 0 30px rgba(100, 255, 120, 0.75) } } @keyframes animate-btn-play { 0% { box-shadow: inset 0 0 0 transparent } 100% { box-shadow: inset 0 0 30px rgba(100, 255, 120, 0.75) } } .typed-cursor { opacity: 1; -webkit-animation: blink .7s infinite; animation: blink .7s infinite } @keyframes blink { 0% { opacity: 1 } 50% { opacity: 0 } 100% { opacity: 1 } } @-webkit-keyframes blink { 0% { opacity: 1 } 50% { opacity: 0 } 100% { opacity: 1 } } zepto.min.js 0000644 00000063422 15043717150 0007037 0 ustar 00 /* Zepto v1.2.0 - zepto event ajax form ie - zeptojs.com/license */ !function(t,e){"function"==typeof define&&define.amd?define(function(){return e(t)}):e(t)}(this,function(t){var e=function(){function $(t){return null==t?String(t):S[C.call(t)]||"object"}function F(t){return"function"==$(t)}function k(t){return null!=t&&t==t.window}function M(t){return null!=t&&t.nodeType==t.DOCUMENT_NODE}function R(t){return"object"==$(t)}function Z(t){return R(t)&&!k(t)&&Object.getPrototypeOf(t)==Object.prototype}function z(t){var e=!!t&&"length"in t&&t.length,n=r.type(t);return"function"!=n&&!k(t)&&("array"==n||0===e||"number"==typeof e&&e>0&&e-1 in t)}function q(t){return a.call(t,function(t){return null!=t})}function H(t){return t.length>0?r.fn.concat.apply([],t):t}function I(t){return t.replace(/::/g,"/").replace(/([A-Z]+)([A-Z][a-z])/g,"$1_$2").replace(/([a-z\d])([A-Z])/g,"$1_$2").replace(/_/g,"-").toLowerCase()}function V(t){return t in l?l[t]:l[t]=new RegExp("(^|\\s)"+t+"(\\s|$)")}function _(t,e){return"number"!=typeof e||h[I(t)]?e:e+"px"}function B(t){var e,n;return c[t]||(e=f.createElement(t),f.body.appendChild(e),n=getComputedStyle(e,"").getPropertyValue("display"),e.parentNode.removeChild(e),"none"==n&&(n="block"),c[t]=n),c[t]}function U(t){return"children"in t?u.call(t.children):r.map(t.childNodes,function(t){return 1==t.nodeType?t:void 0})}function X(t,e){var n,r=t?t.length:0;for(n=0;r>n;n++)this[n]=t[n];this.length=r,this.selector=e||""}function J(t,r,i){for(n in r)i&&(Z(r[n])||L(r[n]))?(Z(r[n])&&!Z(t[n])&&(t[n]={}),L(r[n])&&!L(t[n])&&(t[n]=[]),J(t[n],r[n],i)):r[n]!==e&&(t[n]=r[n])}function W(t,e){return null==e?r(t):r(t).filter(e)}function Y(t,e,n,r){return F(e)?e.call(t,n,r):e}function G(t,e,n){null==n?t.removeAttribute(e):t.setAttribute(e,n)}function K(t,n){var r=t.className||"",i=r&&r.baseVal!==e;return n===e?i?r.baseVal:r:void(i?r.baseVal=n:t.className=n)}function Q(t){try{return t?"true"==t||("false"==t?!1:"null"==t?null:+t+""==t?+t:/^[\[\{]/.test(t)?r.parseJSON(t):t):t}catch(e){return t}}function tt(t,e){e(t);for(var n=0,r=t.childNodes.length;r>n;n++)tt(t.childNodes[n],e)}var e,n,r,i,O,P,o=[],s=o.concat,a=o.filter,u=o.slice,f=t.document,c={},l={},h={"column-count":1,columns:1,"font-weight":1,"line-height":1,opacity:1,"z-index":1,zoom:1},p=/^\s*<(\w+|!)[^>]*>/,d=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,m=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,g=/^(?:body|html)$/i,v=/([A-Z])/g,y=["val","css","html","text","data","width","height","offset"],x=["after","prepend","before","append"],b=f.createElement("table"),E=f.createElement("tr"),j={tr:f.createElement("tbody"),tbody:b,thead:b,tfoot:b,td:E,th:E,"*":f.createElement("div")},w=/complete|loaded|interactive/,T=/^[\w-]*$/,S={},C=S.toString,N={},A=f.createElement("div"),D={tabindex:"tabIndex",readonly:"readOnly","for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder",contenteditable:"contentEditable"},L=Array.isArray||function(t){return t instanceof Array};return N.matches=function(t,e){if(!e||!t||1!==t.nodeType)return!1;var n=t.matches||t.webkitMatchesSelector||t.mozMatchesSelector||t.oMatchesSelector||t.matchesSelector;if(n)return n.call(t,e);var r,i=t.parentNode,o=!i;return o&&(i=A).appendChild(t),r=~N.qsa(i,e).indexOf(t),o&&A.removeChild(t),r},O=function(t){return t.replace(/-+(.)?/g,function(t,e){return e?e.toUpperCase():""})},P=function(t){return a.call(t,function(e,n){return t.indexOf(e)==n})},N.fragment=function(t,n,i){var o,s,a;return d.test(t)&&(o=r(f.createElement(RegExp.$1))),o||(t.replace&&(t=t.replace(m,"<$1></$2>")),n===e&&(n=p.test(t)&&RegExp.$1),n in j||(n="*"),a=j[n],a.innerHTML=""+t,o=r.each(u.call(a.childNodes),function(){a.removeChild(this)})),Z(i)&&(s=r(o),r.each(i,function(t,e){y.indexOf(t)>-1?s[t](e):s.attr(t,e)})),o},N.Z=function(t,e){return new X(t,e)},N.isZ=function(t){return t instanceof N.Z},N.init=function(t,n){var i;if(!t)return N.Z();if("string"==typeof t)if(t=t.trim(),"<"==t[0]&&p.test(t))i=N.fragment(t,RegExp.$1,n),t=null;else{if(n!==e)return r(n).find(t);i=N.qsa(f,t)}else{if(F(t))return r(f).ready(t);if(N.isZ(t))return t;if(L(t))i=q(t);else if(R(t))i=[t],t=null;else if(p.test(t))i=N.fragment(t.trim(),RegExp.$1,n),t=null;else{if(n!==e)return r(n).find(t);i=N.qsa(f,t)}}return N.Z(i,t)},r=function(t,e){return N.init(t,e)},r.extend=function(t){var e,n=u.call(arguments,1);return"boolean"==typeof t&&(e=t,t=n.shift()),n.forEach(function(n){J(t,n,e)}),t},N.qsa=function(t,e){var n,r="#"==e[0],i=!r&&"."==e[0],o=r||i?e.slice(1):e,s=T.test(o);return t.getElementById&&s&&r?(n=t.getElementById(o))?[n]:[]:1!==t.nodeType&&9!==t.nodeType&&11!==t.nodeType?[]:u.call(s&&!r&&t.getElementsByClassName?i?t.getElementsByClassName(o):t.getElementsByTagName(e):t.querySelectorAll(e))},r.contains=f.documentElement.contains?function(t,e){return t!==e&&t.contains(e)}:function(t,e){for(;e&&(e=e.parentNode);)if(e===t)return!0;return!1},r.type=$,r.isFunction=F,r.isWindow=k,r.isArray=L,r.isPlainObject=Z,r.isEmptyObject=function(t){var e;for(e in t)return!1;return!0},r.isNumeric=function(t){var e=Number(t),n=typeof t;return null!=t&&"boolean"!=n&&("string"!=n||t.length)&&!isNaN(e)&&isFinite(e)||!1},r.inArray=function(t,e,n){return o.indexOf.call(e,t,n)},r.camelCase=O,r.trim=function(t){return null==t?"":String.prototype.trim.call(t)},r.uuid=0,r.support={},r.expr={},r.noop=function(){},r.map=function(t,e){var n,i,o,r=[];if(z(t))for(i=0;i<t.length;i++)n=e(t[i],i),null!=n&&r.push(n);else for(o in t)n=e(t[o],o),null!=n&&r.push(n);return H(r)},r.each=function(t,e){var n,r;if(z(t)){for(n=0;n<t.length;n++)if(e.call(t[n],n,t[n])===!1)return t}else for(r in t)if(e.call(t[r],r,t[r])===!1)return t;return t},r.grep=function(t,e){return a.call(t,e)},t.JSON&&(r.parseJSON=JSON.parse),r.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(t,e){S["[object "+e+"]"]=e.toLowerCase()}),r.fn={constructor:N.Z,length:0,forEach:o.forEach,reduce:o.reduce,push:o.push,sort:o.sort,splice:o.splice,indexOf:o.indexOf,concat:function(){var t,e,n=[];for(t=0;t<arguments.length;t++)e=arguments[t],n[t]=N.isZ(e)?e.toArray():e;return s.apply(N.isZ(this)?this.toArray():this,n)},map:function(t){return r(r.map(this,function(e,n){return t.call(e,n,e)}))},slice:function(){return r(u.apply(this,arguments))},ready:function(t){return w.test(f.readyState)&&f.body?t(r):f.addEventListener("DOMContentLoaded",function(){t(r)},!1),this},get:function(t){return t===e?u.call(this):this[t>=0?t:t+this.length]},toArray:function(){return this.get()},size:function(){return this.length},remove:function(){return this.each(function(){null!=this.parentNode&&this.parentNode.removeChild(this)})},each:function(t){return o.every.call(this,function(e,n){return t.call(e,n,e)!==!1}),this},filter:function(t){return F(t)?this.not(this.not(t)):r(a.call(this,function(e){return N.matches(e,t)}))},add:function(t,e){return r(P(this.concat(r(t,e))))},is:function(t){return this.length>0&&N.matches(this[0],t)},not:function(t){var n=[];if(F(t)&&t.call!==e)this.each(function(e){t.call(this,e)||n.push(this)});else{var i="string"==typeof t?this.filter(t):z(t)&&F(t.item)?u.call(t):r(t);this.forEach(function(t){i.indexOf(t)<0&&n.push(t)})}return r(n)},has:function(t){return this.filter(function(){return R(t)?r.contains(this,t):r(this).find(t).size()})},eq:function(t){return-1===t?this.slice(t):this.slice(t,+t+1)},first:function(){var t=this[0];return t&&!R(t)?t:r(t)},last:function(){var t=this[this.length-1];return t&&!R(t)?t:r(t)},find:function(t){var e,n=this;return e=t?"object"==typeof t?r(t).filter(function(){var t=this;return o.some.call(n,function(e){return r.contains(e,t)})}):1==this.length?r(N.qsa(this[0],t)):this.map(function(){return N.qsa(this,t)}):r()},closest:function(t,e){var n=[],i="object"==typeof t&&r(t);return this.each(function(r,o){for(;o&&!(i?i.indexOf(o)>=0:N.matches(o,t));)o=o!==e&&!M(o)&&o.parentNode;o&&n.indexOf(o)<0&&n.push(o)}),r(n)},parents:function(t){for(var e=[],n=this;n.length>0;)n=r.map(n,function(t){return(t=t.parentNode)&&!M(t)&&e.indexOf(t)<0?(e.push(t),t):void 0});return W(e,t)},parent:function(t){return W(P(this.pluck("parentNode")),t)},children:function(t){return W(this.map(function(){return U(this)}),t)},contents:function(){return this.map(function(){return this.contentDocument||u.call(this.childNodes)})},siblings:function(t){return W(this.map(function(t,e){return a.call(U(e.parentNode),function(t){return t!==e})}),t)},empty:function(){return this.each(function(){this.innerHTML=""})},pluck:function(t){return r.map(this,function(e){return e[t]})},show:function(){return this.each(function(){"none"==this.style.display&&(this.style.display=""),"none"==getComputedStyle(this,"").getPropertyValue("display")&&(this.style.display=B(this.nodeName))})},replaceWith:function(t){return this.before(t).remove()},wrap:function(t){var e=F(t);if(this[0]&&!e)var n=r(t).get(0),i=n.parentNode||this.length>1;return this.each(function(o){r(this).wrapAll(e?t.call(this,o):i?n.cloneNode(!0):n)})},wrapAll:function(t){if(this[0]){r(this[0]).before(t=r(t));for(var e;(e=t.children()).length;)t=e.first();r(t).append(this)}return this},wrapInner:function(t){var e=F(t);return this.each(function(n){var i=r(this),o=i.contents(),s=e?t.call(this,n):t;o.length?o.wrapAll(s):i.append(s)})},unwrap:function(){return this.parent().each(function(){r(this).replaceWith(r(this).children())}),this},clone:function(){return this.map(function(){return this.cloneNode(!0)})},hide:function(){return this.css("display","none")},toggle:function(t){return this.each(function(){var n=r(this);(t===e?"none"==n.css("display"):t)?n.show():n.hide()})},prev:function(t){return r(this.pluck("previousElementSibling")).filter(t||"*")},next:function(t){return r(this.pluck("nextElementSibling")).filter(t||"*")},html:function(t){return 0 in arguments?this.each(function(e){var n=this.innerHTML;r(this).empty().append(Y(this,t,e,n))}):0 in this?this[0].innerHTML:null},text:function(t){return 0 in arguments?this.each(function(e){var n=Y(this,t,e,this.textContent);this.textContent=null==n?"":""+n}):0 in this?this.pluck("textContent").join(""):null},attr:function(t,r){var i;return"string"!=typeof t||1 in arguments?this.each(function(e){if(1===this.nodeType)if(R(t))for(n in t)G(this,n,t[n]);else G(this,t,Y(this,r,e,this.getAttribute(t)))}):0 in this&&1==this[0].nodeType&&null!=(i=this[0].getAttribute(t))?i:e},removeAttr:function(t){return this.each(function(){1===this.nodeType&&t.split(" ").forEach(function(t){G(this,t)},this)})},prop:function(t,e){return t=D[t]||t,1 in arguments?this.each(function(n){this[t]=Y(this,e,n,this[t])}):this[0]&&this[0][t]},removeProp:function(t){return t=D[t]||t,this.each(function(){delete this[t]})},data:function(t,n){var r="data-"+t.replace(v,"-$1").toLowerCase(),i=1 in arguments?this.attr(r,n):this.attr(r);return null!==i?Q(i):e},val:function(t){return 0 in arguments?(null==t&&(t=""),this.each(function(e){this.value=Y(this,t,e,this.value)})):this[0]&&(this[0].multiple?r(this[0]).find("option").filter(function(){return this.selected}).pluck("value"):this[0].value)},offset:function(e){if(e)return this.each(function(t){var n=r(this),i=Y(this,e,t,n.offset()),o=n.offsetParent().offset(),s={top:i.top-o.top,left:i.left-o.left};"static"==n.css("position")&&(s.position="relative"),n.css(s)});if(!this.length)return null;if(f.documentElement!==this[0]&&!r.contains(f.documentElement,this[0]))return{top:0,left:0};var n=this[0].getBoundingClientRect();return{left:n.left+t.pageXOffset,top:n.top+t.pageYOffset,width:Math.round(n.width),height:Math.round(n.height)}},css:function(t,e){if(arguments.length<2){var i=this[0];if("string"==typeof t){if(!i)return;return i.style[O(t)]||getComputedStyle(i,"").getPropertyValue(t)}if(L(t)){if(!i)return;var o={},s=getComputedStyle(i,"");return r.each(t,function(t,e){o[e]=i.style[O(e)]||s.getPropertyValue(e)}),o}}var a="";if("string"==$(t))e||0===e?a=I(t)+":"+_(t,e):this.each(function(){this.style.removeProperty(I(t))});else for(n in t)t[n]||0===t[n]?a+=I(n)+":"+_(n,t[n])+";":this.each(function(){this.style.removeProperty(I(n))});return this.each(function(){this.style.cssText+=";"+a})},index:function(t){return t?this.indexOf(r(t)[0]):this.parent().children().indexOf(this[0])},hasClass:function(t){return t?o.some.call(this,function(t){return this.test(K(t))},V(t)):!1},addClass:function(t){return t?this.each(function(e){if("className"in this){i=[];var n=K(this),o=Y(this,t,e,n);o.split(/\s+/g).forEach(function(t){r(this).hasClass(t)||i.push(t)},this),i.length&&K(this,n+(n?" ":"")+i.join(" "))}}):this},removeClass:function(t){return this.each(function(n){if("className"in this){if(t===e)return K(this,"");i=K(this),Y(this,t,n,i).split(/\s+/g).forEach(function(t){i=i.replace(V(t)," ")}),K(this,i.trim())}})},toggleClass:function(t,n){return t?this.each(function(i){var o=r(this),s=Y(this,t,i,K(this));s.split(/\s+/g).forEach(function(t){(n===e?!o.hasClass(t):n)?o.addClass(t):o.removeClass(t)})}):this},scrollTop:function(t){if(this.length){var n="scrollTop"in this[0];return t===e?n?this[0].scrollTop:this[0].pageYOffset:this.each(n?function(){this.scrollTop=t}:function(){this.scrollTo(this.scrollX,t)})}},scrollLeft:function(t){if(this.length){var n="scrollLeft"in this[0];return t===e?n?this[0].scrollLeft:this[0].pageXOffset:this.each(n?function(){this.scrollLeft=t}:function(){this.scrollTo(t,this.scrollY)})}},position:function(){if(this.length){var t=this[0],e=this.offsetParent(),n=this.offset(),i=g.test(e[0].nodeName)?{top:0,left:0}:e.offset();return n.top-=parseFloat(r(t).css("margin-top"))||0,n.left-=parseFloat(r(t).css("margin-left"))||0,i.top+=parseFloat(r(e[0]).css("border-top-width"))||0,i.left+=parseFloat(r(e[0]).css("border-left-width"))||0,{top:n.top-i.top,left:n.left-i.left}}},offsetParent:function(){return this.map(function(){for(var t=this.offsetParent||f.body;t&&!g.test(t.nodeName)&&"static"==r(t).css("position");)t=t.offsetParent;return t})}},r.fn.detach=r.fn.remove,["width","height"].forEach(function(t){var n=t.replace(/./,function(t){return t[0].toUpperCase()});r.fn[t]=function(i){var o,s=this[0];return i===e?k(s)?s["inner"+n]:M(s)?s.documentElement["scroll"+n]:(o=this.offset())&&o[t]:this.each(function(e){s=r(this),s.css(t,Y(this,i,e,s[t]()))})}}),x.forEach(function(n,i){var o=i%2;r.fn[n]=function(){var n,a,s=r.map(arguments,function(t){var i=[];return n=$(t),"array"==n?(t.forEach(function(t){return t.nodeType!==e?i.push(t):r.zepto.isZ(t)?i=i.concat(t.get()):void(i=i.concat(N.fragment(t)))}),i):"object"==n||null==t?t:N.fragment(t)}),u=this.length>1;return s.length<1?this:this.each(function(e,n){a=o?n:n.parentNode,n=0==i?n.nextSibling:1==i?n.firstChild:2==i?n:null;var c=r.contains(f.documentElement,a);s.forEach(function(e){if(u)e=e.cloneNode(!0);else if(!a)return r(e).remove();a.insertBefore(e,n),c&&tt(e,function(e){if(!(null==e.nodeName||"SCRIPT"!==e.nodeName.toUpperCase()||e.type&&"text/javascript"!==e.type||e.src)){var n=e.ownerDocument?e.ownerDocument.defaultView:t;n.eval.call(n,e.innerHTML)}})})})},r.fn[o?n+"To":"insert"+(i?"Before":"After")]=function(t){return r(t)[n](this),this}}),N.Z.prototype=X.prototype=r.fn,N.uniq=P,N.deserializeValue=Q,r.zepto=N,r}();return t.Zepto=e,void 0===t.$&&(t.$=e),function(e){function h(t){return t._zid||(t._zid=n++)}function p(t,e,n,r){if(e=d(e),e.ns)var i=m(e.ns);return(a[h(t)]||[]).filter(function(t){return t&&(!e.e||t.e==e.e)&&(!e.ns||i.test(t.ns))&&(!n||h(t.fn)===h(n))&&(!r||t.sel==r)})}function d(t){var e=(""+t).split(".");return{e:e[0],ns:e.slice(1).sort().join(" ")}}function m(t){return new RegExp("(?:^| )"+t.replace(" "," .* ?")+"(?: |$)")}function g(t,e){return t.del&&!f&&t.e in c||!!e}function v(t){return l[t]||f&&c[t]||t}function y(t,n,i,o,s,u,f){var c=h(t),p=a[c]||(a[c]=[]);n.split(/\s/).forEach(function(n){if("ready"==n)return e(document).ready(i);var a=d(n);a.fn=i,a.sel=s,a.e in l&&(i=function(t){var n=t.relatedTarget;return!n||n!==this&&!e.contains(this,n)?a.fn.apply(this,arguments):void 0}),a.del=u;var c=u||i;a.proxy=function(e){if(e=T(e),!e.isImmediatePropagationStopped()){e.data=o;var n=c.apply(t,e._args==r?[e]:[e].concat(e._args));return n===!1&&(e.preventDefault(),e.stopPropagation()),n}},a.i=p.length,p.push(a),"addEventListener"in t&&t.addEventListener(v(a.e),a.proxy,g(a,f))})}function x(t,e,n,r,i){var o=h(t);(e||"").split(/\s/).forEach(function(e){p(t,e,n,r).forEach(function(e){delete a[o][e.i],"removeEventListener"in t&&t.removeEventListener(v(e.e),e.proxy,g(e,i))})})}function T(t,n){return(n||!t.isDefaultPrevented)&&(n||(n=t),e.each(w,function(e,r){var i=n[e];t[e]=function(){return this[r]=b,i&&i.apply(n,arguments)},t[r]=E}),t.timeStamp||(t.timeStamp=Date.now()),(n.defaultPrevented!==r?n.defaultPrevented:"returnValue"in n?n.returnValue===!1:n.getPreventDefault&&n.getPreventDefault())&&(t.isDefaultPrevented=b)),t}function S(t){var e,n={originalEvent:t};for(e in t)j.test(e)||t[e]===r||(n[e]=t[e]);return T(n,t)}var r,n=1,i=Array.prototype.slice,o=e.isFunction,s=function(t){return"string"==typeof t},a={},u={},f="onfocusin"in t,c={focus:"focusin",blur:"focusout"},l={mouseenter:"mouseover",mouseleave:"mouseout"};u.click=u.mousedown=u.mouseup=u.mousemove="MouseEvents",e.event={add:y,remove:x},e.proxy=function(t,n){var r=2 in arguments&&i.call(arguments,2);if(o(t)){var a=function(){return t.apply(n,r?r.concat(i.call(arguments)):arguments)};return a._zid=h(t),a}if(s(n))return r?(r.unshift(t[n],t),e.proxy.apply(null,r)):e.proxy(t[n],t);throw new TypeError("expected function")},e.fn.bind=function(t,e,n){return this.on(t,e,n)},e.fn.unbind=function(t,e){return this.off(t,e)},e.fn.one=function(t,e,n,r){return this.on(t,e,n,r,1)};var b=function(){return!0},E=function(){return!1},j=/^([A-Z]|returnValue$|layer[XY]$|webkitMovement[XY]$)/,w={preventDefault:"isDefaultPrevented",stopImmediatePropagation:"isImmediatePropagationStopped",stopPropagation:"isPropagationStopped"};e.fn.delegate=function(t,e,n){return this.on(e,t,n)},e.fn.undelegate=function(t,e,n){return this.off(e,t,n)},e.fn.live=function(t,n){return e(document.body).delegate(this.selector,t,n),this},e.fn.die=function(t,n){return e(document.body).undelegate(this.selector,t,n),this},e.fn.on=function(t,n,a,u,f){var c,l,h=this;return t&&!s(t)?(e.each(t,function(t,e){h.on(t,n,a,e,f)}),h):(s(n)||o(u)||u===!1||(u=a,a=n,n=r),(u===r||a===!1)&&(u=a,a=r),u===!1&&(u=E),h.each(function(r,o){f&&(c=function(t){return x(o,t.type,u),u.apply(this,arguments)}),n&&(l=function(t){var r,s=e(t.target).closest(n,o).get(0);return s&&s!==o?(r=e.extend(S(t),{currentTarget:s,liveFired:o}),(c||u).apply(s,[r].concat(i.call(arguments,1)))):void 0}),y(o,t,u,a,n,l||c)}))},e.fn.off=function(t,n,i){var a=this;return t&&!s(t)?(e.each(t,function(t,e){a.off(t,n,e)}),a):(s(n)||o(i)||i===!1||(i=n,n=r),i===!1&&(i=E),a.each(function(){x(this,t,i,n)}))},e.fn.trigger=function(t,n){return t=s(t)||e.isPlainObject(t)?e.Event(t):T(t),t._args=n,this.each(function(){t.type in c&&"function"==typeof this[t.type]?this[t.type]():"dispatchEvent"in this?this.dispatchEvent(t):e(this).triggerHandler(t,n)})},e.fn.triggerHandler=function(t,n){var r,i;return this.each(function(o,a){r=S(s(t)?e.Event(t):t),r._args=n,r.target=a,e.each(p(a,t.type||t),function(t,e){return i=e.proxy(r),r.isImmediatePropagationStopped()?!1:void 0})}),i},"focusin focusout focus blur load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select keydown keypress keyup error".split(" ").forEach(function(t){e.fn[t]=function(e){return 0 in arguments?this.bind(t,e):this.trigger(t)}}),e.Event=function(t,e){s(t)||(e=t,t=e.type);var n=document.createEvent(u[t]||"Events"),r=!0;if(e)for(var i in e)"bubbles"==i?r=!!e[i]:n[i]=e[i];return n.initEvent(t,r,!0),T(n)}}(e),function(e){function p(t,n,r){var i=e.Event(n);return e(t).trigger(i,r),!i.isDefaultPrevented()}function d(t,e,n,i){return t.global?p(e||r,n,i):void 0}function m(t){t.global&&0===e.active++&&d(t,null,"ajaxStart")}function g(t){t.global&&!--e.active&&d(t,null,"ajaxStop")}function v(t,e){var n=e.context;return e.beforeSend.call(n,t,e)===!1||d(e,n,"ajaxBeforeSend",[t,e])===!1?!1:void d(e,n,"ajaxSend",[t,e])}function y(t,e,n,r){var i=n.context,o="success";n.success.call(i,t,o,e),r&&r.resolveWith(i,[t,o,e]),d(n,i,"ajaxSuccess",[e,n,t]),b(o,e,n)}function x(t,e,n,r,i){var o=r.context;r.error.call(o,n,e,t),i&&i.rejectWith(o,[n,e,t]),d(r,o,"ajaxError",[n,r,t||e]),b(e,n,r)}function b(t,e,n){var r=n.context;n.complete.call(r,e,t),d(n,r,"ajaxComplete",[e,n]),g(n)}function E(t,e,n){if(n.dataFilter==j)return t;var r=n.context;return n.dataFilter.call(r,t,e)}function j(){}function w(t){return t&&(t=t.split(";",2)[0]),t&&(t==c?"html":t==f?"json":a.test(t)?"script":u.test(t)&&"xml")||"text"}function T(t,e){return""==e?t:(t+"&"+e).replace(/[&?]{1,2}/,"?")}function S(t){t.processData&&t.data&&"string"!=e.type(t.data)&&(t.data=e.param(t.data,t.traditional)),!t.data||t.type&&"GET"!=t.type.toUpperCase()&&"jsonp"!=t.dataType||(t.url=T(t.url,t.data),t.data=void 0)}function C(t,n,r,i){return e.isFunction(n)&&(i=r,r=n,n=void 0),e.isFunction(r)||(i=r,r=void 0),{url:t,data:n,success:r,dataType:i}}function O(t,n,r,i){var o,s=e.isArray(n),a=e.isPlainObject(n);e.each(n,function(n,u){o=e.type(u),i&&(n=r?i:i+"["+(a||"object"==o||"array"==o?n:"")+"]"),!i&&s?t.add(u.name,u.value):"array"==o||!r&&"object"==o?O(t,u,r,n):t.add(n,u)})}var i,o,n=+new Date,r=t.document,s=/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,a=/^(?:text|application)\/javascript/i,u=/^(?:text|application)\/xml/i,f="application/json",c="text/html",l=/^\s*$/,h=r.createElement("a");h.href=t.location.href,e.active=0,e.ajaxJSONP=function(i,o){if(!("type"in i))return e.ajax(i);var c,p,s=i.jsonpCallback,a=(e.isFunction(s)?s():s)||"Zepto"+n++,u=r.createElement("script"),f=t[a],l=function(t){e(u).triggerHandler("error",t||"abort")},h={abort:l};return o&&o.promise(h),e(u).on("load error",function(n,r){clearTimeout(p),e(u).off().remove(),"error"!=n.type&&c?y(c[0],h,i,o):x(null,r||"error",h,i,o),t[a]=f,c&&e.isFunction(f)&&f(c[0]),f=c=void 0}),v(h,i)===!1?(l("abort"),h):(t[a]=function(){c=arguments},u.src=i.url.replace(/\?(.+)=\?/,"?$1="+a),r.head.appendChild(u),i.timeout>0&&(p=setTimeout(function(){l("timeout")},i.timeout)),h)},e.ajaxSettings={type:"GET",beforeSend:j,success:j,error:j,complete:j,context:null,global:!0,xhr:function(){return new t.XMLHttpRequest},accepts:{script:"text/javascript, application/javascript, application/x-javascript",json:f,xml:"application/xml, text/xml",html:c,text:"text/plain"},crossDomain:!1,timeout:0,processData:!0,cache:!0,dataFilter:j},e.ajax=function(n){var u,f,s=e.extend({},n||{}),a=e.Deferred&&e.Deferred();for(i in e.ajaxSettings)void 0===s[i]&&(s[i]=e.ajaxSettings[i]);m(s),s.crossDomain||(u=r.createElement("a"),u.href=s.url,u.href=u.href,s.crossDomain=h.protocol+"//"+h.host!=u.protocol+"//"+u.host),s.url||(s.url=t.location.toString()),(f=s.url.indexOf("#"))>-1&&(s.url=s.url.slice(0,f)),S(s);var c=s.dataType,p=/\?.+=\?/.test(s.url);if(p&&(c="jsonp"),s.cache!==!1&&(n&&n.cache===!0||"script"!=c&&"jsonp"!=c)||(s.url=T(s.url,"_="+Date.now())),"jsonp"==c)return p||(s.url=T(s.url,s.jsonp?s.jsonp+"=?":s.jsonp===!1?"":"callback=?")),e.ajaxJSONP(s,a);var P,d=s.accepts[c],g={},b=function(t,e){g[t.toLowerCase()]=[t,e]},C=/^([\w-]+:)\/\//.test(s.url)?RegExp.$1:t.location.protocol,N=s.xhr(),O=N.setRequestHeader;if(a&&a.promise(N),s.crossDomain||b("X-Requested-With","XMLHttpRequest"),b("Accept",d||"*/*"),(d=s.mimeType||d)&&(d.indexOf(",")>-1&&(d=d.split(",",2)[0]),N.overrideMimeType&&N.overrideMimeType(d)),(s.contentType||s.contentType!==!1&&s.data&&"GET"!=s.type.toUpperCase())&&b("Content-Type",s.contentType||"application/x-www-form-urlencoded"),s.headers)for(o in s.headers)b(o,s.headers[o]);if(N.setRequestHeader=b,N.onreadystatechange=function(){if(4==N.readyState){N.onreadystatechange=j,clearTimeout(P);var t,n=!1;if(N.status>=200&&N.status<300||304==N.status||0==N.status&&"file:"==C){if(c=c||w(s.mimeType||N.getResponseHeader("content-type")),"arraybuffer"==N.responseType||"blob"==N.responseType)t=N.response;else{t=N.responseText;try{t=E(t,c,s),"script"==c?(1,eval)(t):"xml"==c?t=N.responseXML:"json"==c&&(t=l.test(t)?null:e.parseJSON(t))}catch(r){n=r}if(n)return x(n,"parsererror",N,s,a)}y(t,N,s,a)}else x(N.statusText||null,N.status?"error":"abort",N,s,a)}},v(N,s)===!1)return N.abort(),x(null,"abort",N,s,a),N;var A="async"in s?s.async:!0;if(N.open(s.type,s.url,A,s.username,s.password),s.xhrFields)for(o in s.xhrFields)N[o]=s.xhrFields[o];for(o in g)O.apply(N,g[o]);return s.timeout>0&&(P=setTimeout(function(){N.onreadystatechange=j,N.abort(),x(null,"timeout",N,s,a)},s.timeout)),N.send(s.data?s.data:null),N},e.get=function(){return e.ajax(C.apply(null,arguments))},e.post=function(){var t=C.apply(null,arguments);return t.type="POST",e.ajax(t)},e.getJSON=function(){var t=C.apply(null,arguments);return t.dataType="json",e.ajax(t)},e.fn.load=function(t,n,r){if(!this.length)return this;var a,i=this,o=t.split(/\s/),u=C(t,n,r),f=u.success;return o.length>1&&(u.url=o[0],a=o[1]),u.success=function(t){i.html(a?e("<div>").html(t.replace(s,"")).find(a):t),f&&f.apply(i,arguments)},e.ajax(u),this};var N=encodeURIComponent;e.param=function(t,n){var r=[];return r.add=function(t,n){e.isFunction(n)&&(n=n()),null==n&&(n=""),this.push(N(t)+"="+N(n))},O(r,t,n),r.join("&").replace(/%20/g,"+")}}(e),function(t){t.fn.serializeArray=function(){var e,n,r=[],i=function(t){return t.forEach?t.forEach(i):void r.push({name:e,value:t})};return this[0]&&t.each(this[0].elements,function(r,o){n=o.type,e=o.name,e&&"fieldset"!=o.nodeName.toLowerCase()&&!o.disabled&&"submit"!=n&&"reset"!=n&&"button"!=n&&"file"!=n&&("radio"!=n&&"checkbox"!=n||o.checked)&&i(t(o).val())}),r},t.fn.serialize=function(){var t=[];return this.serializeArray().forEach(function(e){t.push(encodeURIComponent(e.name)+"="+encodeURIComponent(e.value))}),t.join("&")},t.fn.submit=function(e){if(0 in arguments)this.bind("submit",e);else if(this.length){var n=t.Event("submit");this.eq(0).trigger(n),n.isDefaultPrevented()||this.get(0).submit()}return this}}(e),function(){try{getComputedStyle(void 0)}catch(e){var n=getComputedStyle;t.getComputedStyle=function(t,e){try{return n(t,e)}catch(r){return null}}}}(),e}); detection.js 0000644 00000004401 15043717150 0007062 0 ustar 00 var detection = (function() { var mod = {is:{}}, d, ua = navigator.userAgent; mod.detect = { html5: function() { return document.createElement('canvas').getContext !== undefined; }, touch: function() { var supportsTouch = 'ontouchstart' in window || navigator.msMaxTouchPoints; return !!supportsTouch; }, android: function() { return !!ua.match(/Android/i); }, ios: function() { return !!ua.match(/iPhone|iPad|iPod/i); }, ios7: function(){ return mod.detect.ios && ua.match(/version\/7\./i); }, bb10: function() { return !!ua.match(/BB10/i); }, windows: function() { return !!ua.match(/Windows/i); }, webkitVersion: function() { var regex = new RegExp(/AppleWebKit\/([\d.]+)/), result = regex.exec(ua), webkitVersion = result === null ? false : parseFloat(result[1]); return webkitVersion; }, androidStockBrowser: function() { if (mod.is.android && mod.is.webkitVersion && mod.is.webkitVersion < 537) { return true; } return false; }, standalone: function() { return !!window.navigator.standalone; }, smartphone: function() { return (ua.match(/Android.*Mobile|iPhone|IEMobile|WPDesktop|BB10/i)) ? true : false; }, tablet: function() { // Android smartphones have the combination Android...Mobile, tablets only Android var androidTablet = (mod.is.android && !mod.is.smartphone), iPad = ua.match(/iPad/i) ? true : false; return (androidTablet || iPad); }, pc: function() { return (!mod.is.smartphone && !mod.is.tablet); }, phantom: function() { return !!(window.callPhantom || ua.match(/PhantomJS/)); }, iframe: function(){ return window.self != window.top; } }; for (d in mod.detect) { if (typeof mod.detect[d] === 'function') { mod.is[d] = mod.detect[d](); } } return mod; })(); famobi_analytics_v1.js 0000644 00000024634 15043717150 0011030 0 ustar 00 !function(a, b) { var famobi_analytics = { 'stats' : {}, // params for achivements etc. - custom key-value pairs 'events': [], // list of logged events, for debugging purposes 'currentScreen': '', 'pageTitle' : '', // STATS 'trackStats': function(key, value) { return new Promise(function(resolve, reject) { var res = {}; var values = {}; if (typeof key === 'string') { values[key] = value; } var statsValidator = function() { for (var k in values) { var testKey = (typeof key === 'string' && key.length && key.length <= 42) && key.match(/^[a-z\_0-9]+$/); if (!testKey) { console.warn("trackStats(): key '" + key + "' contains not only lowercase letters, numbers and underscore ([a-z_0-9]), maximum length: 42 characters"); return false; } } return true; } var isValid = statsValidator(); if (!isValid) { reject("trackStats(): invalid params " + JSON.stringify(key, value)); return false; } var updateKey = function(key, value) { if (typeof key === 'string' && key.length) { if (key in famobi_analytics.stats && (typeof value === "undefined" || value === null)) { delete famobi_analytics.stats[key]; } else { if(typeof value !== "undefined" && value) { famobi_analytics.stats[key] = value; } } return true; } else { throw("trackStats(): key is not a string or an Object"); return false; } } if(key && typeof key === 'object') { for(var k in key) { value = key[k] updateKey(k, value); } res = key; } else { updateKey(key, value); res[key] = value; } if (famobi.hasOwnProperty("adapters")) { famobi.adapters.run("analytics", "trackStats", key, value); } resolve(res); }); }, 'getStats': function() { // for debugging purposes return new Promise(function(resolve, reject) { resolve(famobi_analytics.stats); }); }, // EVENTS 'trackEvent': function(event, params) { return new Promise(function(resolve, reject) { if (typeof famobi_analytics[event] === "undefined") { reject('trackEvent(): unknown event \'' + event + '\''); return false; } params = params || {}; if (typeof params !== "object" && params !== null) { reject('trackEvent(): second parameter needs to be an object'); return false; } var paramsValidator = function() { var availableParams = { 'levelName': '', 'reason': [ 'timeout', 'dead', 'wrong_answer', 'quit', 'draw' ], 'levelScore': -0.0, 'liveScore': -0.0, 'totalScore': -0.0, 'bgmVolume': 0.0, 'sfxVolume': 0.0 }; var requiredParams = { 'EVENT_LEVELFAIL': ['levelName', 'reason'], 'EVENT_LEVELRESTART': ['levelName'], 'EVENT_LEVELSTART': ['levelName'], 'EVENT_LEVELSUCCESS': ['levelName'], 'EVENT_LEVELSCORE': ['levelName', 'levelScore'], 'EVENT_LIVESCORE': ['liveScore'], 'EVENT_TOTALSCORE': ['totalScore'], 'EVENT_VOLUMECHANGE': ['bgmVolume', 'sfxVolume'], 'EVENT_CUSTOM': [] }; if (typeof requiredParams[event] !== "undefined" && Object.keys(params).length === 0) { console.warn("trackEvent(): '" + event + "' requires at least one parameter"); return false; } if (typeof requiredParams[event] === "undefined") { return true; } var k = 0; var name = ''; var param = null; for (k; k < requiredParams[event].length; k++) { name = requiredParams[event][k]; param = availableParams[name]; if (typeof param === "string") { if (typeof params[name] !== "string") { console.warn("trackEvent(): required param '" + name + "' has to be of type string"); return false; } } if (typeof param === "number") { if (typeof params[name] !== "number") { console.warn("trackEvent(): required param '" + name + "' has to be of type number"); return false; } } if (typeof param === "object") { if (param.indexOf(params[name]) === -1) { console.warn("trackEvent(): required param '" + name + "' has to be one of \"" + param.join('", "') + "\""); return false; } } } return true; }; var isValid = paramsValidator(); if (!isValid) { return reject("trackEvent(): invalid params " + JSON.stringify(params)); } famobi_analytics.events.push({event: event, params: params}); if (famobi.hasOwnProperty("adapters")) { famobi.adapters.run("analytics", "trackEvent", event, params); } event !== "EVENT_LIVESCORE" && console.log(event, params); /* if (famobi_analytics.TRIGGER_AD.indexOf(event) > -1) { return famobi.showAd(function() { resolve(event, params); }); } */ if (famobi_analytics.TRIGGER_SCORE.indexOf(event) > -1) { if(!window.famobi.hasFeature("highscores")) { return resolve(event, params); } var promises = []; switch(event) { case "EVENT_LEVELSCORE": famobi.submitHighscore(params['levelName'], params['levelScore'], true); break; case "EVENT_TOTALSCORE": famobi.submitHighscore('TOTAL', params['totalScore'], true); break; default: } return Promise.all(promises).then(function() { resolve(event, params); }); } if (famobi_analytics.TRIGGER_LEVELSUCCESS.indexOf(event) > -1) { return Promise.all([ window.famobi.showAd() ]).then(function(){ resolve(event, params); }); } if (famobi_analytics.TRIGGER_LEVELFAIL.indexOf(event) > -1) { if(params.reason == "quit") { return resolve(event, params); } return Promise.all([ window.famobi.showAd() ]).then(function(){ resolve(event, params); }); } if (famobi_analytics.TRIGGER_LEVELSTART.indexOf(event) > -1) { return Promise.all([]).then(function(){ resolve(event, params); }); } /* if (famobi_analytics.TRIGGER_LEVELSCORE.indexOf(event) > -1) { famobi.submitHighscore(params['levelName'], params['levelScore']); return resolve(event, params); } if (famobi_analytics.TRIGGER_TOTALSCORE.indexOf(event) > -1) { famobi.submitHighscore('TOTAL', params['totalScore']); return resolve(event, params); } */ if (famobi_analytics.TRIGGER_LIVESCORE.indexOf(event) > -1) { famobi.sendLiveScore(params['liveScore']); return resolve(event, params); } return resolve(event, params); }); }, 'getEvents': function() { // for debugging purposes return new Promise(function(resolve, reject) { resolve(famobi_analytics.events); }); }, EVENT_CUSTOM: 'EVENT_CUSTOM', EVENT_LEVELFAIL: 'EVENT_LEVELFAIL', EVENT_LEVELRESTART: 'EVENT_LEVELRESTART', EVENT_LEVELSTART: 'EVENT_LEVELSTART', EVENT_LEVELSUCCESS: 'EVENT_LEVELSUCCESS', EVENT_LIVESCORE: 'EVENT_LIVESCORE', EVENT_LEVELSCORE: 'EVENT_LEVELSCORE', EVENT_TOTALSCORE: 'EVENT_TOTALSCORE', EVENT_TUTORIALCOMPLETED: 'EVENT_TUTORIALCOMPLETED', EVENT_TUTORIALSKIPPED: 'EVENT_TUTORIALSKIPPED', EVENT_VOLUMECHANGE: 'EVENT_VOLUMECHANGE', EVENT_PAUSE: 'EVENT_PAUSE', EVENT_RESUME: 'EVENT_RESUME', // SCREEN 'trackScreen': function(screen, pageTitle) { return new Promise(function(resolve, reject) { var requiredPageTitleScreens = [ 'SCREEN_OTHER' ]; if (typeof famobi_analytics[screen] === "undefined") { reject("trackScreen(): unknown screen '" + screen + "'"); return false; } if (!pageTitle && screen.indexOf(requiredPageTitleScreens) > -1) { reject("trackScreen(): screen '" + screen + "' requires param 'pageTitle'"); return false; } if (pageTitle && typeof pageTitle !== "string") { reject("trackScreen(): required param 'pageTitle' has to be a non-empty string"); return false; } famobi_analytics.currentScreen = screen; famobi_analytics.pageTitle = pageTitle; if (famobi.hasOwnProperty("adapters")) { famobi.adapters.run("analytics", "trackScreen", screen, pageTitle); } resolve(screen, pageTitle); }); }, 'getScreen': function() { return famobi_analytics.currentScreen; }, 'getPageTitle': function() { return famobi_analytics.pageTitle; }, SCREEN_OTHER: 'SCREEN_OTHER', // custom, use pageTitle to differentiate SCREEN_BONUS: 'SCREEN_BONUS', // bonus screen, e.g. extra chance SCREEN_CHARACTER: 'SCREEN_CHARACTER', // Select character SCREEN_CREDITS: 'SCREEN_CREDITS', // credits screen, if used SCREEN_GAMERESULT: 'SCREEN_GAMERESULT', // result screen with total score (game over) SCREEN_HELP: 'SCREEN_HELP', // help screen SCREEN_HOME: 'SCREEN_HOME', // home screen (start screen) SCREEN_LEVEL: 'SCREEN_LEVEL', // level screen while playing SCREEN_LEVELINTRO: 'SCREEN_LEVELINTRO', // level has not yet begun (optional) SCREEN_LEVELLOADING: 'SCREEN_LEVELLOADING', // level is loading (optional) SCREEN_LEVELRESULT: 'SCREEN_LEVELRESULT', // result screen with level score SCREEN_LEVELSELECT: 'SCREEN_LEVELSELECT', // level select screen SCREEN_PAUSE: 'SCREEN_PAUSE', // pause screen SCREEN_SETTINGS: 'SCREEN_SETTINGS', // settings screen (advanced game settings) SCREEN_SHOP: 'SCREEN_SHOP', // when the game features an ingame shop, use pageTitle to differentiate between items SCREEN_SPLASH: 'SCREEN_SPLASH', // splash screen, if used SCREEN_TUTORIAL: 'SCREEN_TUTORIAL', // tutorial screen(s), use pageTitle to differentiate between multiple tutorial screens TRIGGER_SCORE: ['EVENT_LEVELSCORE', 'EVENT_TOTALSCORE'], TRIGGER_LIVESCORE: ['EVENT_LIVESCORE'], TRIGGER_LEVELFAIL: ['EVENT_LEVELFAIL'], TRIGGER_LEVELSUCCESS:['EVENT_LEVELSUCCESS'], TRIGGER_LEVELSTART: ['EVENT_LEVELSTART', 'EVENT_LEVELRESTART'], }; // export famobi_analytics object to global object b[a] = famobi_analytics; }('famobi_analytics', window); tresor.js 0000644 00000040003 15043717150 0006420 0 ustar 00 window["TRESOR"] = ( function () { let log = false; let initialized = false; let compression = null; let debugging = false; let async = true; let STORAGE; let LZString; const STORAGES = { "SESSION": 0, "LOCALSTORAGE": 1, "YTGAME": 2, "GAMESNACKS": 3, "FAMOBI": 4, "WAKOOL": 5, 0: "SESSION", 1: "LOCALSTORAGE", 2: "YTGAME", 3: "GAMESNACKS", 4: "FAMOBI", 5: "WAKOOL" }; const testKey = "__test__"; function init(_storageType = 0, _fallback = false, _log = false, _async = true, _compression = null) { if(typeof _storageType === "object") { storageType = _storageType.storageType || 0; fallback = _storageType.fallback || false; log = _storageType.log || false; async = !!_storageType.async; compression = _storageType.compression || null; } else { storageType = _storageType || 0; fallback = _fallback || false; log = _log || false; async = !!_async; compression = _compression || null; } switch(compression) { case "lz-string": /** * lz-string 1.5.0 (https://github.com/pieroxy/lz-string/) **/ LZString=function(){var r=String.fromCharCode,o="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-$",e={};function t(r,o){if(!e[r]){e[r]={};for(var n=0;n<r.length;n++)e[r][r.charAt(n)]=n}return e[r][o]}var i={compressToBase64:function(r){if(null==r)return"";var n=i._compress(r,6,function(r){return o.charAt(r)});switch(n.length%4){default:case 0:return n;case 1:return n+"===";case 2:return n+"==";case 3:return n+"="}},decompressFromBase64:function(r){return null==r?"":""==r?null:i._decompress(r.length,32,function(n){return t(o,r.charAt(n))})},compressToUTF16:function(o){return null==o?"":i._compress(o,15,function(o){return r(o+32)})+" "},decompressFromUTF16:function(r){return null==r?"":""==r?null:i._decompress(r.length,16384,function(o){return r.charCodeAt(o)-32})},compressToUint8Array:function(r){for(var o=i.compress(r),n=new Uint8Array(2*o.length),e=0,t=o.length;e<t;e++){var s=o.charCodeAt(e);n[2*e]=s>>>8,n[2*e+1]=s%256}return n},decompressFromUint8Array:function(o){if(null==o)return i.decompress(o);for(var n=new Array(o.length/2),e=0,t=n.length;e<t;e++)n[e]=256*o[2*e]+o[2*e+1];var s=[];return n.forEach(function(o){s.push(r(o))}),i.decompress(s.join(""))},compressToEncodedURIComponent:function(r){return null==r?"":i._compress(r,6,function(r){return n.charAt(r)})},decompressFromEncodedURIComponent:function(r){return null==r?"":""==r?null:(r=r.replace(/ /g,"+"),i._decompress(r.length,32,function(o){return t(n,r.charAt(o))}))},compress:function(o){return i._compress(o,16,function(o){return r(o)})},_compress:function(r,o,n){if(null==r)return"";var e,t,i,s={},u={},a="",p="",c="",l=2,f=3,h=2,d=[],m=0,v=0;for(i=0;i<r.length;i+=1)if(a=r.charAt(i),Object.prototype.hasOwnProperty.call(s,a)||(s[a]=f++,u[a]=!0),p=c+a,Object.prototype.hasOwnProperty.call(s,p))c=p;else{if(Object.prototype.hasOwnProperty.call(u,c)){if(c.charCodeAt(0)<256){for(e=0;e<h;e++)m<<=1,v==o-1?(v=0,d.push(n(m)),m=0):v++;for(t=c.charCodeAt(0),e=0;e<8;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}else{for(t=1,e=0;e<h;e++)m=m<<1|t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t=0;for(t=c.charCodeAt(0),e=0;e<16;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}0==--l&&(l=Math.pow(2,h),h++),delete u[c]}else for(t=s[c],e=0;e<h;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1;0==--l&&(l=Math.pow(2,h),h++),s[p]=f++,c=String(a)}if(""!==c){if(Object.prototype.hasOwnProperty.call(u,c)){if(c.charCodeAt(0)<256){for(e=0;e<h;e++)m<<=1,v==o-1?(v=0,d.push(n(m)),m=0):v++;for(t=c.charCodeAt(0),e=0;e<8;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}else{for(t=1,e=0;e<h;e++)m=m<<1|t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t=0;for(t=c.charCodeAt(0),e=0;e<16;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}0==--l&&(l=Math.pow(2,h),h++),delete u[c]}else for(t=s[c],e=0;e<h;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1;0==--l&&(l=Math.pow(2,h),h++)}for(t=2,e=0;e<h;e++)m=m<<1|1&t,v==o-1?(v=0,d.push(n(m)),m=0):v++,t>>=1;for(;;){if(m<<=1,v==o-1){d.push(n(m));break}v++}return d.join("")},decompress:function(r){return null==r?"":""==r?null:i._decompress(r.length,32768,function(o){return r.charCodeAt(o)})},_decompress:function(o,n,e){var t,i,s,u,a,p,c,l=[],f=4,h=4,d=3,m="",v=[],g={val:e(0),position:n,index:1};for(t=0;t<3;t+=1)l[t]=t;for(s=0,a=Math.pow(2,2),p=1;p!=a;)u=g.val&g.position,g.position>>=1,0==g.position&&(g.position=n,g.val=e(g.index++)),s|=(u>0?1:0)*p,p<<=1;switch(s){case 0:for(s=0,a=Math.pow(2,8),p=1;p!=a;)u=g.val&g.position,g.position>>=1,0==g.position&&(g.position=n,g.val=e(g.index++)),s|=(u>0?1:0)*p,p<<=1;c=r(s);break;case 1:for(s=0,a=Math.pow(2,16),p=1;p!=a;)u=g.val&g.position,g.position>>=1,0==g.position&&(g.position=n,g.val=e(g.index++)),s|=(u>0?1:0)*p,p<<=1;c=r(s);break;case 2:return""}for(l[3]=c,i=c,v.push(c);;){if(g.index>o)return"";for(s=0,a=Math.pow(2,d),p=1;p!=a;)u=g.val&g.position,g.position>>=1,0==g.position&&(g.position=n,g.val=e(g.index++)),s|=(u>0?1:0)*p,p<<=1;switch(c=s){case 0:for(s=0,a=Math.pow(2,8),p=1;p!=a;)u=g.val&g.position,g.position>>=1,0==g.position&&(g.position=n,g.val=e(g.index++)),s|=(u>0?1:0)*p,p<<=1;l[h++]=r(s),c=h-1,f--;break;case 1:for(s=0,a=Math.pow(2,16),p=1;p!=a;)u=g.val&g.position,g.position>>=1,0==g.position&&(g.position=n,g.val=e(g.index++)),s|=(u>0?1:0)*p,p<<=1;l[h++]=r(s),c=h-1,f--;break;case 2:return v.join("")}if(0==f&&(f=Math.pow(2,d),d++),l[c])m=l[c];else{if(c!==h)return null;m=i+i.charAt(0)}v.push(m),l[h++]=i+m.charAt(0),i=m,0==--f&&(f=Math.pow(2,d),d++)}}};return i}();"function"==typeof define&&define.amd?define(function(){return LZString}):"undefined"!=typeof module&&null!=module?module.exports=LZString:"undefined"!=typeof angular&&null!=angular&&angular.module("LZString",[]).factory("LZString",function(){return LZString}); break; default: // do nothing } return new Promise((resolve, reject) => { log && console.log("[tresor] initializing..."); setDriver(storageType, fallback).then( () => { log && console.log("[tresor] ok"); initialized = true; resolve(); }, () => { log && console.log("[tresor] failed"); reject(); } ); }); }; function compress(str) { switch(compression) { case "lz-string": debugging && console.log("compress data (%s):", compression); debugging && console.log(str); str = LZString.compress(str); debugging && console.log(str); return str; default: return str; } }; function decompress(str) { switch(compression) { case "lz-string": debugging && console.log("decompress data (%s):", compression); debugging && console.log(str); str = LZString.decompress(str); debugging && console.log(str); default: return str; } } function setDriver(storageType = 0, fallback = true) { // SESSION STORAGE const SESSION_STORAGE = { data: {}, init: function() { return Promise.resolve(); }, setItem: function(keyPrefix, value) { this.data[keyPrefix] = value; return Promise.resolve({}); }, getItem: function(keyPrefix) { return Promise.resolve({"value": this.data[keyPrefix] || null}); }, removeItem: function(keyPrefix) { delete this.data[keyPrefix]; return Promise.resolve({}); }, keys: function() { return Promise.resolve({"keys": Object.keys(this.data)}); }, clear: function() { this.data = {}; return Promise.resolve({}); } }; // YTGAME STORAGE const YTGAME_STORAGE = { data: {}, init: function() { return new Promise(resolve => { window["ytgame"]["game"]["loadData"]().then(data => { try{ this.data = JSON.parse(decompress(data)); if(this.data === null) { this.data = {}; } } catch(e) { this.data = {}; } resolve(); }); }); }, setItem: function(keyPrefix, value) { return new Promise(resolve => { this.data[keyPrefix] = value; window["ytgame"]["game"]["saveData"](compress(JSON.stringify(this.data))).then( () => {resolve({})}, e => {resolve({"err": e})}); }); }, getItem: function(keyPrefix) { return Promise.resolve({"value": this.data[keyPrefix] || null}); }, removeItem: function(keyPrefix) { delete this.data[keyPrefix]; return new Promise(resolve => { window["ytgame"]["game"]["saveData"](compress(JSON.stringify(this.data))).then( () => {resolve({})}, e => {resolve({"err": e})}); }); }, keys: function() { return Promise.resolve({"keys": Object.keys(this.data)}); }, clear: function() { this.data = {}; return new Promise(resolve => { window["ytgame"]["game"]["saveData"](compress(JSON.stringify(this.data))).then( () => {resolve({})}, e => {resolve({"err": e})}); }); } }; // LOCALSTORAGE const LOCAL_STORAGE = { data: {}, init: function() { return new Promise(resolve => { window["localStorage"]["setItem"](testKey, testKey); window["localStorage"]["removeItem"](testKey); resolve(); }); }, setItem: function(keyPrefix, value) { window["localStorage"]["setItem"](keyPrefix, value); return Promise.resolve({}); }, getItem: function(keyPrefix) { let value = window["localStorage"]["getItem"](keyPrefix); return Promise.resolve({"value": value || null}); }, removeItem: function(keyPrefix) { window["localStorage"]["removeItem"](keyPrefix); return Promise.resolve({}); }, keys: function() { function getAllLocalStorageKeys() { const keys = []; const len = window["localStorage"].length; for (let i = 0; i < len; i++) { keys.push(window["localStorage"]["key"](i)); } return keys; } return Promise.resolve({"keys": getAllLocalStorageKeys()}); }, clear: function() { window["localStorage"]["clear"](); return Promise.resolve({}); } }; // GAMESNACKS STORAGE const GAMESNACKS_STORAGE = { data: {}, init: function() { return new Promise(resolve => { let data = window["GameSnacks"]["storage"]["getItem"]("savegame"); try{ this.data = JSON.parse(decompress(data)); if(this.data === null) { this.data = {}; } } catch(e) { this.data = {}; } resolve(); }); }, setItem: function(keyPrefix, value) { return new Promise(resolve => { this.data[keyPrefix] = value; try{ window["GameSnacks"]["storage"]["setItem"]("savegame", compress(JSON.stringify(this.data))); resolve({}); } catch(e) { resolve({"err": e}); } }); }, getItem: function(keyPrefix) { return Promise.resolve({"value": this.data[keyPrefix] || null}); }, removeItem: function(keyPrefix) { return new Promise(resolve => { delete this.data[keyPrefix]; try{ window["GameSnacks"]["storage"]["setItem"]("savegame", compress(JSON.stringify(this.data))); resolve({}); } catch(e) { resolve({"err": e}); } }); }, keys: function() { return Promise.resolve({"keys": Object.keys(this.data)}); }, clear: function() { this.data = {}; window["GameSnacks"]["storage"]["clear"](); return Promise.resolve({}); } }; // FAMOBI STORAGE const FAMOBI_STORAGE = { data: {}, init: function() { return new Promise(resolve => { window["famobi"]["localStorage"]["setItem"](testKey, testKey); window["famobi"]["localStorage"]["removeItem"](testKey); resolve(); }); }, setItem: function(keyPrefix, value) { window["famobi"]["localStorage"]["setItem"](keyPrefix, value); return Promise.resolve({}); }, getItem: function(keyPrefix) { let value = window["famobi"]["localStorage"]["getItem"](keyPrefix); return Promise.resolve({"value": value || null}); }, removeItem: function(keyPrefix) { window["famobi"]["localStorage"]["removeItem"](keyPrefix); return Promise.resolve({}); }, keys: function() { let keys = window["famobi"]["localStorage"]["getKeys"](); return Promise.resolve({"keys": keys}); }, clear: function() { window["famobi"]["localStorage"]["clear"](); return Promise.resolve({}); } }; // WAKOOL STORAGE const WAKOOL_STORAGE = { data: {}, path: "/" + window.famobi_gameID + "/", storageType: "userStorage", // appStorage init: function() { return new Promise(resolve => { wakool[this.storageType].keys(this.path).then(keys => { keys.forEach(key => { wakool[this.storageType].get(this.path + key).then(result => { if(result) { this.data[key] = result; } }).catch(e => { resolve({err: e}); }); }); resolve(); }).catch(e => { resolve({err: e}); }); }); }, setItem: function(keyPrefix, value) { this.data[keyPrefix] = value; wakool[this.storageType].put(this.path + keyPrefix, JSON.stringify(value)); return Promise.resolve({}); }, getItem: function(keyPrefix) { return Promise.resolve({"value": this.data[keyPrefix] || null}); }, removeItem: function(keyPrefix) { delete this.data[keyPrefix]; wakool[this.storageType].remove(this.path + keyPrefix); return Promise.resolve({}); }, keys: function() { return Promise.resolve({"keys": Object.keys(this.data)}); }, clear: function() { this.keys().then(result => { result.keys.forEach(key => { this.removeItem(key); }); }); return Promise.resolve({}); } }; switch(storageType) { case 0: STORAGE = SESSION_STORAGE; break; case 1: STORAGE = LOCAL_STORAGE; break; case 2: STORAGE = YTGAME_STORAGE; break; case 3: STORAGE = GAMESNACKS_STORAGE; break; case 4: STORAGE = FAMOBI_STORAGE; break; case 5: STORAGE = WAKOOL_STORAGE; break; default: log && console.log("[tresor] unknown storage type. Using session/object storage as fallback."); storageType = 0; STORAGE = SESSION_STORAGE; } STORAGE.type = storageType; log && console.log("[tresor] selected storage: %s", STORAGES[STORAGE.type]); return new Promise((resolve, reject) => { STORAGE.init().then(() => { resolve(); }).catch(e => { if(fallback) { log && console.log("[tresor] failed! using Session storage as fallback..."); setDriver(0, false); STORAGE.init().then(() => { resolve(); }); } else { reject(); } }); }); }; function setItem(keyPrefix, value, callback) { STORAGE.setItem(keyPrefix, value).then(result => { if(typeof callback === "function") { callback(result["err"] || false, value); } }); }; function getItem(keyPrefix, callback) { if(!async) { return STORAGE.data[keyPrefix] || null; } STORAGE.getItem(keyPrefix).then(result => { if(typeof callback === "function") { callback(result["err"] || false, result["value"]); } }); }; function removeItem(keyPrefix, callback) { STORAGE.removeItem(keyPrefix).then(result => { if(typeof callback === "function") { callback(result["err"] || false); } }); }; function keys(callback) { if(!async) { return Object.keys(STORAGE.data); } STORAGE.keys().then(result => { if(typeof callback === "function") { callback(result["err"] || false, result["keys"]); } }); }; function clear(callback) { STORAGE.clear().then(result => { if(typeof callback === "function") { callback(result.keys, result.err); } }); }; return { init, setDriver, setItem, getItem, removeItem, keys, clear, get initialized() { return initialized; }, STORAGES }; } )(); // window["TRESOR"]["init"](3, true, false); fenster.js 0000644 00000005713 15043717150 0006561 0 ustar 00 if (typeof window !== "undefined" && typeof fenster === "undefined" && typeof window.fenster === "undefined") { !(function(a, b) { const fenster = ( function() { let isDebug = false; try{ const searchParams = new URL(window.location.href).searchParams; isDebug = ["1", "true"].includes(searchParams.get("debug")); } catch(e) { } isDebug && console.log("fenster...") let innerWidth = window.innerWidth; let innerHeight = window.innerHeight; let interval = null; let fnResize = null; function subscribeToOffsetUpdates(_fnResize) { fnResize = _fnResize; }; function init() { isDebug && console.log("init 'fenster'..."); window.famobi.onOffsetChange(offsets => { isDebug && console.log("[offsets] onOffsetChange"); update(); }); update(); }; function update() { isDebug && console.log( "[offsets] top: %s, right: %s, bottom: %s, left: %s", window.famobi.getOffsets().top, window.famobi.getOffsets().right, window.famobi.getOffsets().bottom, window.famobi.getOffsets().left ); innerWidth = window.innerWidth - (window.famobi?.getOffsets()?.right || 0); innerHeight = window.innerHeight - (window.famobi?.getOffsets()?.bottom || 0); isDebug && console.log("[offsets] innerWidth: %s, innerHeight: %s", innerWidth, innerHeight ); if(typeof fnResize === "function") { fnResize(); } }; function test(right = 0, bottom = 0) { const offsets = { top: 0, right, bottom, left: 0 }; window.famobi.getOffsets = () => { return offsets; } window.famobi.adapters.run("viewport", "offsetChanged", offsets); }; addEventListener("resize", (event) => { update(); }); interval = setInterval(() => { isDebug && console.log("[fenster] checking for onOffsetChange") if (typeof window.famobi?.onOffsetChange === "function") { clearInterval(interval); init(); } }, 250); return { get innerHeight() { return innerHeight; }, get innerWidth() { return innerWidth; }, update: update, subscribeToOffsetUpdates: subscribeToOffsetUpdates, test: test }; } )(); b[a] = fenster; })("fenster", window); }
| ver. 1.4 |
Github
|
.
| PHP 8.2.29 | Генераци� �траницы: 0 |
proxy
|
phpinfo
|
�а�тройка