// SETUP ///////////////////////////////////////////////////////////// // these functions set up specific areas after the boot function // created a basic framework. All of these functions should only ever // be run once. window.setupLargeImagePreview = function() { $('#portaldetails').on('click', '.imgpreview img', function() { var ex = $('#largepreview'); if(ex.length > 0) { ex.remove(); return; } var img = $(this).parent().html(); var w = $(this)[0].naturalWidth/2; var h = $(this)[0].naturalHeight/2; var c = $('#portaldetails').attr('class'); $('body').append( '
' + img + '
' ); $('#largepreview').click(function() { $(this).remove() }); }); } window.setupStyles = function() { $('head').append(''); } window.setupMap = function() { var osmOpt = {attribution: 'Map data © OpenStreetMap contributors', maxZoom: 18}; var osm = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', osmOpt); var cmOpt = {attribution: 'Map data © OpenStreetMap contributors, Imagery © CloudMade', maxZoom: 18}; var cmMin = new L.TileLayer('http://{s}.tile.cloudmade.com/654cef5fd49a432ab81267e200ecc502/22677/256/{z}/{x}/{y}.png', cmOpt); var cmMid = new L.TileLayer('http://{s}.tile.cloudmade.com/654cef5fd49a432ab81267e200ecc502/999/256/{z}/{x}/{y}.png', cmOpt); var views = [cmMid, cmMin, osm, new L.Google('INGRESS'), new L.Google('ROADMAP'), new L.Google('SATELLITE'), new L.Google('HYBRID')]; portalsLayer = L.layerGroup([]); linksLayer = L.layerGroup([]); fieldsLayer = L.layerGroup([]); window.map = new L.Map('map', $.extend(getPosition(), {zoomControl: false})); try { map.addLayer(views[readCookie('ingress.intelmap.type')]); } catch(e) { map.addLayer(views[0]); } map.addLayer(portalsLayer); map.addLayer(fieldsLayer, true); map.addLayer(linksLayer, true); map.addControl(new L.Control.Layers({ 'OSM Cloudmade Midnight': views[0], 'OSM Cloudmade Minimal': views[1], 'OSM Mapnik': views[2], 'Google Roads Ingress Style': views[3], 'Google Roads': views[4], 'Google Satellite': views[5], 'Google Hybrid': views[6] }, { 'Portals': portalsLayer, 'Links': linksLayer, 'Fields': fieldsLayer })); map.attributionControl.setPrefix(''); // listen for changes and store them in cookies map.on('moveend', window.storeMapPosition); map.on('zoomend', window.storeMapPosition); $("[name='leaflet-base-layers']").change(function () { writeCookie('ingress.intelmap.type', $(this).parent().index()); }); // map update status handling map.on('zoomstart', function() { window.mapRunsUserAction = true }); map.on('movestart', function() { window.mapRunsUserAction = true }); map.on('zoomend', function() { window.mapRunsUserAction = false }); map.on('moveend', function() { window.mapRunsUserAction = false }); // update map hooks map.on('zoomstart', window.requests.abort); map.on('zoomend', function() { window.startRefreshTimeout(500) }); map.on('movestart', window.requests.abort ); map.on('moveend', function() { window.startRefreshTimeout(500) }); // run once on init window.requestData(); window.startRefreshTimeout(); }; // renders player details into the website. Since the player info is // included as inline script in the original site, the data is static // and cannot be updated. window.setupPlayerStat = function() { var level; var ap = parseInt(PLAYER.ap); for(level = 0; level < 7; level++) { if(ap < MIN_AP_FOR_LEVEL[level]) break; } var thisLvlAp = MIN_AP_FOR_LEVEL[level-1]; var nextLvlAp = MIN_AP_FOR_LEVEL[level] || ap; var lvlUpAp = digits(nextLvlAp-ap); var lvlApProg = Math.round((ap-thisLvlAp)/(nextLvlAp-thisLvlAp)*100); var xmMax = MAX_XM_PER_LEVEL[level]; var xmRatio = Math.round(PLAYER.energy/xmMax*100); var cls = PLAYER.team === 'ALIENS' ? 'enl' : 'res'; var t = 'Level:\t\t' + level + '\n' + 'XM:\t\t\t' + PLAYER.energy + ' / ' + xmMax + '\n' + 'AP:\t\t\t' + digits(ap) + '\n' + (level < 8 ? 'level up in:\t' + lvlUpAp + ' AP' : 'Congrats! (neeeeerd)') + '\n\Invites:\t\t'+PLAYER.available_invites; + '\n\nNote: your player stats can only be updated by a full reload (F5)'; $('#playerstat').html('' + '

'+level+' ' + ''+PLAYER.nickname+'' + '
' + 'XM: '+xmRatio+'%' + '' + (level < 8 ? 'level: '+lvlApProg+'%' : 'max level') + '' + '
' + '

' ); } // BOOTING /////////////////////////////////////////////////////////// function boot() { console.log('loading done, booting'); window.setupStyles(); window.setupMap(); window.setupGeosearch(); window.setupRedeem(); window.setupLargeImagePreview(); window.updateGameScore(); window.setupPlayerStat(); // read here ONCE, so the URL is only evaluated one time after the // necessary data has been loaded. urlPortal = getURLParam('pguid'); $('#sidebar').show(); } // this is the minified load.js script that allows us to easily load // further javascript files async as well as in order. // https://github.com/chriso/load.js // Copyright (c) 2010 Chris O'Hara . MIT Licensed function asyncLoadScript(a){return function(b,c){var d=document.createElement("script");d.type="text/javascript",d.src=a,d.onload=b,d.onerror=c,d.onreadystatechange=function(){var a=this.readyState;if(a==="loaded"||a==="complete")d.onreadystatechange=null,b()},head.insertBefore(d,head.firstChild)}}(function(a){a=a||{};var b={},c,d;c=function(a,d,e){var f=a.halt=!1;a.error=function(a){throw a},a.next=function(c){c&&(f=!1);if(!a.halt&&d&&d.length){var e=d.shift(),g=e.shift();f=!0;try{b[g].apply(a,[e,e.length,g])}catch(h){a.error(h)}}return a};for(var g in b){if(typeof a[g]=="function")continue;(function(e){a[e]=function(){var g=Array.prototype.slice.call(arguments);if(e==="onError"){if(d)return b.onError.apply(a,[g,g.length]),a;var h={};return b.onError.apply(h,[g,g.length]),c(h,null,"onError")}return g.unshift(e),d?(a.then=a[e],d.push(g),f?a:a.next()):c({},[g],e)}})(g)}return e&&(a.then=a[e]),a.call=function(b,c){c.unshift(b),d.unshift(c),a.next(!0)},a.next()},d=a.addMethod=function(d){var e=Array.prototype.slice.call(arguments),f=e.pop();for(var g=0,h=e.length;g